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Product Features 


= Optimum Integration for Lowest Cost 
Solution 


— Integrated IEEE 802.3 1OBASE-T and 
100BASE-TX compatible PHY 


—Glueless 32-bit PCI master interface 
—Glueless CardBus master interface 


— Modem interface for combination 
solutions in PCI, CardBus, and MiniPCI 
designs 


—PXE Support in Combo Designs 

— 128 Kbyte Flash interface 

—Integrated power management functions 
—Thin BGA 15mm? package 


m= Wired for Management and Reduced Total 
Cost of Ownership 


—Wired for Management support 


—System Management Bus support for 
Total Cost of Ownership support 


—Power management capabilities 


— ACPI and PCI Power Management 
standards compliance 


— Wake on “interesting” packets and link 
status change support 


—Magic Packet* support 
—Remote power up support 


Datasheet 


High Performance Networking Functions 


—Chained memory structure similar to the 
82558, 82557, and 82596 


—Improved dynamic transmit chaining 
with multiple priorities transmit queues 


—Backward compatible software to the 
82558 and 82557 


—Full Duplex support at both 10 and 100 
Mbps 
—IEEE 802.3u Auto-Negotiation support 


—3 Kbyte transmit and 3 Kbyte receive 
FIFOs 


—Fast back-to-back transmission support 
with minimum interframe spacing 


—IEEE 802.3x 100BASE-TX Flow 
Control support 


—Adaptive Technology 

—TCP/UDP checksum offload capabilities 
Low Power Features 

—Low power 3.3 V device 

—Efficient dynamic standby mode 
—Deep power down support 

—Clockrun protocol support 
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Date Revision Description 
Jan. 1999 1.0 First release. 
May 1999 2.0 * Preliminary 82559 C-step updates: 


. Added Section 1.3, "Enhancements to the 82559 C-Step" 


. Changed resistance values for RBIAS pins in Section 3.6, "PHY Sig- 
nals" 


* Changed signal names (Section 3.4, "System Management Bus (SMB) 
Interface Signals"): 


° Alert Bus Data: ALERTD (previously) to SMBD 
. Alert Bus Clock: ALERTCLK (previously) to SMBCLK 
. Bus Alert: BUSALRT (previously) to SMBALRT 


* Changed value of PCI power management in the Capability ID Register from 
01H to 02H (Section 8.1.18, "Capability ID Register") 

* Changed value of bits 18:16 in the Power Management Capabilities Register 
from 001b to 010b (Section 8.1.20, "Power Management Capabilities Regis- 
ter") 

* Changed power consumption values in Table 15. Ethernet Data Register in 
Section 8.1.22, "Data Register" 

* Changed name of Modem Capabilities Pointer (Modem Cap_Ptr) register in 
PCI Configuration space to Modem (Section 8.2, "Function 1: Modem PCI 
Configuration Space") 


¢ Added Section 11.0, "82559 Test Port Functionality" 
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Introduction 





1.1 


1.2 
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82559 Overview 


The 82559 is Intel's second generation fully integrated 1|OBASE-T/100BASE-TX LAN solution. 
The 82559 consists of both the Media Access Controller (MAC) and the physical layer (PHY) 
interface combined into a single component solution. The 82559 builds on the basic functionality 
of the 82558. In addition to the 82558, the 82559 has added new features and enhancements: 


¢ Host-side CardBus interface 
¢ Enhanced power management implementation 
¢ Enhanced Total Cost of Ownership (TCO) support 


¢ Optimized Flash or modem interface support 


The 32-bit PCI/CardBus controller provides enhanced scatter-gather bus mastering capabilities and 
enables the 82559 to perform high speed data transfers over the PCI bus and CardBus. Its bus 
master capabilities enable the component to process high level commands and perform multiple 
operations, which lowers CPU utilization by off-loading communication tasks from the CPU. Two 
large transmit and receive FIFOs of 3 Kbyte each help prevent data underruns and overruns while 
waiting for bus accesses. This enables the 82559 to transmit data with minimum interframe spacing 
(IFS). 


The 82559 can operate in either full duplex or half duplex mode. In full duplex mode the 82559 
adheres with the IEEE 802.3x Flow Control specification. Half duplex performance is enhanced by 
a proprietary collision reduction mechanism. 


The 82559 includes a simple PHY interface to the wire transformer at rates of LOBASE-T and 
100BASE-TX enables reduction in cost, real estate and design complexity. Its Auto-Negotiation 
capability for speed, duplex, and flow control mode reduces cost, real estate, and design 
complexity. 


The 82559 also includes an interface to a serial (4-pin) EEPROM and a parallel interface to a 128 
Kbyte Flash memory. The EEPROM provides power-on initialization for hardware and software 
configuration parameters. The parallel port can be used as either a Flash memory interface or an 
ISA-like interface for modem. 


Combined with a Total Cost of Ownership (TCO) controller, the 82559 can help reduce the total 
cost of ownership in network environments. The device includes a System Management Bus 
(SMB) interface enabling the TCO controller to communicate with a management agent on the 
network. 


Features, Enhancements, and Changes to the 82559 from 
the 82558 


* Glueless 32-bit PCI bus master interface 
¢ Support for latchless Flash interface with up to 128 Kbyte of Flash addressing 


¢ Glueless CardBus master interface 
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Modem interface for combination solution (LAN and modem) in PCI and CardBus designs 


Low power consumption for LAN/modem combination designs to meet CardBus power 
requirements 


Compliance with Advanced Configuration and Power Interface and PCI Power Management 
specifications 


Support for wake-up on interesting packets and link status change 
Support for remote power-up using Wake on LAN* (WOL) technology 
Deep power-down mode support 


Support of Total Cost of Ownership (TCO) management interface and Wired for Management 
(WfM) 


Backward compatible software with 82558 and 82557 
TCP/UDP checksum offload capabilities 
Support for Intel’s Adaptive Technology 


The following is a list of changes that were made from the 82558 B-step Fast Ethernet Controller to 
the 82559 Fast Ethernet Multifunction PCI/CardBusController. 


Use of 3.3 V power supply (82559) versus 5 V power supply 


Individual Address, Multicast Address, and ARP wake-up events merged into extended 
programmable wake-up packet command and removed from the CSMA command 


Receive collision bit in the RFD status word replaced with a TCO indication bit 
SMB port implemented to support TCO management interface 

PHY identifier in MII Register 3 modified 

External PHY support removed 


PHY-based flow control removed (802.3x flow control was not removed) 


13 Enhancements to the 82559 C-Step 


The success of the 82559 B-step in mobile designs has spurred the addition of several new features 
to the device. These enhancements integrate new capabilities into the 82559 for both CardBus and 
MiniPCI system designs: 


Reducing the declared Flash window requirement to 128 bytes from | Mbyte. 


Adding glueless support for PXE Flash ROM in LAN/modem combination designs by adding 
an external gating signal 
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82559 Architectural Overview 





Figure 1. 


2.1 


Datasheet 


Figure | is a high level block diagram of the 82559. It is divided into five main subsystems: a 
parallel subsystem, a FIFO subsystem, the Total Cost of Ownership (TCO) subsystem, the 10/100 
Mbps Carrier Sense Multiple Access with Collision Detect (CSMA/CD) unit, and the 10/100 Mbps 
physical layer (PHY) unit. 
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82559 Block Diagram 


Parallel Subsystem Overview 


The parallel subsystem is broken down into several functional blocks: a PCI bus master interface, a 
micromachine processing unit and its corresponding microcode ROM, and a PCI Target Control/ 
Flash/EEPROM/Modem interface. The parallel subsystem also interfaces to the FIFO subsystem, 
passing data (such as transmit, receive, and configuration data) and command and status 
parameters between these two blocks. 


The dual function LAN and modem interface provides a complete glueless connection to the PCI 
bus and is compliant with the PCI Bus Specification, Revision 2.2. The 82559 provides 32 bits of 
addressing and data, as well as the complete control interface to operate on a PCI bus. As a PCI 
target, it follows the PCI configuration format which allows all accesses to the 82559 to be 
automatically mapped into free memory and I/O space upon initialization of a PCI system. For 
processing of transmit and receive frames, the 82559 operates as a master on the PCI bus, initiating 
zero wait state transfers for accessing these data parameters. 


The 82559 Control/Status Register Block is part of the PCI target element. The Control/Status 
Register block consists of the following 82559 internal control registers: System Control Block 
(SCB), PORT, Flash Control, EEPROM Control, Modem Control and Management Data Interface 
(MDI) Control. 


The micromachine is an embedded processing unit contained in the 82559 that enables Adaptive 
Technology. The micromachine accesses the 82559 microcode ROM working its way through the 
operation codes, opcodes (or instructions), contained in the ROM to perform its functions. 
Parameters accessed from memory such as pointers to data buffers are also used by the 
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micromachine during the processing of transmit or receive frames by the 82559. A typical 
micromachine function is to transfer a data buffer pointer field to the 82559 DMA unit for direct 
access to the data buffer. The micromachine is divided into two units, Receive Unit and Command 
Unit which includes transmit functions. These two units operate independently and concurrently. 
Control is switched between the two units according to the microcode instruction flow. The 
independence of the Receive and Command units in the micromachine allows the 82559 to execute 
commands and receive incoming frames simultaneously, with no real-time CPU intervention. 


The 82559 contains an interface to an external Flash memory, an external serial EEPROM, and 
modem. These three interfaces are multiplexed, and both read and write accesses are supported. 
The Flash may be used for remote boot functions, network statistical and diagnostics functions, and 
management functions. The Flash is mapped into host system memory (anywhere within the 32-bit 
memory address space) for software accesses. It is also mapped into an available boot expansion 
ROM location during boot time of the system. More information on the Flash interface is detailed 
in Section 4.6, “Parallel Flash/Modem Interface” on page 33. The EEPROM is used to store 
relevant information for a LAN connection such as node address, as well as board manufacturing 
and configuration information. Both read and write accesses to the EEPROM are supported by the 
82559. Information on the EEPROM interface is detailed in Section 4.7, “Serial EEPROM 
Interface” on page 33. The modem interface uses an ISA-like signal and is described in more detail 
in Section 6.0, “82559 Modem Functionality” on page 49. 


FIFO Subsystem Overview 


The 82559 FIFO subsystem consists of a 3 Kbyte transmit FIFO and 3 Kbyte receive FIFO. Each 
FIFO is unidirectional and independent of the other. The FIFO subsystem serves as the interface 
between the 82559 parallel side and the serial CSMA/CD unit. It provides a temporary buffer 
storage area for frames as they are either being received or transmitted by the 82559, which 
improves performance: 


¢ Transmit frames can be queued within the transmit FIFO, allowing back-to-back transmission 
within the minimum Interframe Spacing (IFS). 


¢ The storage area in the FIFO allows the 82559 to withstand long PCI bus latencies without 
losing incoming data or corrupting outgoing data. 


® The 82559 transmit FIFO threshold allows the transmit start threshold to be tuned to eliminate 
underruns while concurrent transmits are being performed. 


¢ The FIFO subsection allows extended PCI zero wait state burst accesses to or from the 82559 
for both transmit and receive frames since the transfer is to the FIFO storage area rather than 
directly to the serial link. 


¢ Transmissions resulting in errors (collision detection or data underrun) are retransmitted 
directly from the 82559 FIFO, increasing performance and eliminating the need to re-access 
this data from the host system. 


¢ Incoming runt receive frames (in other words, frames that are less than the legal minimum 
frame size) can be discarded automatically by the 82559 without transferring this faulty data to 
the host system. 
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10/100 Mbps Serial CSMA/CD Unit Overview 


The CSMA/CD unit of the 82559 allows it to be connected to either a 10 or 100 Mbps Ethernet 
network. The CSMA/CD unit performs all of the functions of the 802.3 protocol such as frame 
formatting, frame stripping, collision handling, deferral to link traffic, etc. The CSMA/CD unit can 
also be placed in a full duplex mode which allows simultaneous transmission and reception of 
frames. 


10/100 Mbps Physical Layer Unit 


The Physical Layer (PHY) unit of the 82559 allows connection to either a 10 or 100 Mbps Ethernet 
network. The PHY unit supports Auto-Negotiation for 1OOBASE-TX Full Duplex, 1OOBASE-TX 
Half Duplex, 1OBASE-T Full Duplex, and 1OBASE-T Half Duplex. It also supports three LED pins 
to indicate link status, network activity, and speed. 
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3.0 Signal Descriptions 





3.1 Signal Type Definitions 














Type Name Description 
IN Input The input pin is a standard input only signal. 
The output pin is a Totem Pole Output pin and is a standard 
Our Output active driver. 
T/S Tri-State The tri-state pin is a bidirectional, input/output pin. 





The sustained tri-state pin is an active low tri-state signal owned 
and driven by one agent at a time. The agent asserting the S/T/ 
S pin low must drive it high at least one clock cycle before 
floating the pin. A new agent can only assert an S/T/S signal low 
one clock cycle after it has been tri-stated by the previous 
owner. 


S/T/S Sustained Tri-State 





The open drain pin allows multiple devices to share this signal 


ae Open Brain as a wired-OR. 























A/l Analog Input The analog input pin is used for analog input signals. 
A/O Analog Output The analog output pin is used for analog output signals. 
B Bias The bias pin is an input bias. 





3.2 PCI Bus and CardBus Interface Signals 


3.2.1 Address and Data Signals 





Symbol Type Name and Function 





Address and Data. The address and data lines are multiplexed on the 
same PCI pins. A bus transaction consists of an address phase 
followed by one or more data phases. During the address phase, the 
address and data lines contain the 32-bit physical address. For I/O, 
AD[81:0] T/S this is a byte address; for configuration and memory, it is a Dword 
address. The 82559 uses little-endian byte ordering (in other words, 
AD[31:24] contain the most significant byte and AD[7:0] contain the 
least significant byte). During the data phases, the address and data 
lines contain data. 





Command and Byte Enable. The bus command and byte enable 
signals are multiplexed on the same PCI pins. During the address 
phase, the C/BE# lines define the bus command. During the data 
phase, the C/BE# lines are used as Byte Enables. The Byte Enables 
are valid for the entire data phase and determine which byte lanes 
carry meaningful data. 


Parity. Parity is even across AD[31:0] and C/BE[3:0]# lines. It is stable 
and valid one clock after the address phase. For data phases, PAR is 
stable and valid one clock after either IRDY# is asserted on a write 
PAR T/S transaction or TRDY# is asserted on a read transaction.Once PAR is 
valid, it remains valid until one clock after the completion of the current 
data phase. The master drives PAR for address and write data 
phases; and the target, for read data phases. 


C/BE[3:0]}# | T/S 
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Interface Control Signals 





Symbol 


Type 


Name and Function 





FRAME# 


S/T/S 


Cycle Frame. The cycle frame signal is driven by the current master 
to indicate the beginning and duration of a transaction. FRAME# is 
asserted to indicate the start of a transaction and de-asserted during 
the final data phase. 





IRDY# 


S/T/S 


Initiator Ready. The initiator ready signal indicates the bus master’s 
ability to complete the current data phase and is used in conjunction 
with the target ready (TRDY#) signal. A data phase is completed on 
any clock cycle where both IRDY# and TRDY# are sampled asserted 
(low) simultaneously. 





TRDY# 


S/T/S 


Target Ready. The target ready signal indicates the selected device’s 
ability to complete the current data phase and is used in conjunction 
with the initiator ready (IRDY#) signal. A data phase is completed on 
any clock cycle where both IRDY# and TRDY# are sampled asserted 
(low) simultaneously. 





STOP# 


S/T/S 


Stop. The stop signal is driven by the target to indicate to the initiator 
that it wishes to stop the current transaction. As a bus slave, STOP# is 
driven by the 82559 to inform the bus master to stop the current 
transaction. As a bus master, STOP# is received by the 82559 to stop 
the current transaction. 





IDSEL 


Initialization Device Select. The initialization device select signal is 
used by the 82559 as a chip select during PCI configuration read and 
write transactions. This signal is provided by the host in PCI systems. 
In a CardBus system, this pin should not be connected. 





DEVSEL# 


S/T/S 


Device Select. The device select signal is asserted by the target once 
it has detected its address. As a bus master, the DEVSEL+# is an input 
signal to the 82559 indicating whether any device on the bus has been 
selected. As a bus slave, the 82559 asserts DEVSEL+# to indicate that 
it has decoded its address as the target of the current transaction. 





REQ# 


T/S 


Request. The request signal indicates to the bus arbiter that the 
82559 desires use of the bus. This is a point-to-point signal and every 
bus master has its own REQ#. 





GNT# 


Grant. The grant signal is asserted by the bus arbiter and indicates to 
the 82559 that access to the bus has been granted. This is a point-to- 
point signal and every master has its own GNT#. 





INTA# 


O/D 


Interrupt A. The interrupt A signal is used to request an interrupt by 
the 82559. This is an active low, level triggered interrupt signal. 





SERR# 


O/D 


System Error. The system error signal is used to report address 
parity errors. When an error is detected, SERR# is driven low for a 
single PCI clock. 








PERR# 





S/T/S 





Parity Error. The parity error signal is used to report data parity errors 
during all PCI transactions except a Special Cycle. The parity error pin 
is asserted two clock cycles after the error was detected by the device 
receiving data. The minimum duration of PERR# is one clock for each 
data phase where an error is detected. A device cannot report a parity 
error until it has claimed the access by asserting DEVSEL# and 
completed a data phase. 
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System and Power Management Signals 





Symbol 


Type 


Name and Function 





CLK 


Clock. The Clock signal provides the timing for all PCI transactions 
and is an input signal to every PCI device. The 82559 requires a PCI 
Clock signal (frequency greater than or equal to 16 MHz) for nominal 
operation. The 82559 supports Clock signal suspension using the 
Clockrun protocol. 





CLKRUN# 


IN/OUT 
O/D 


Clockrun. The Clockrun signal is used by the system to pause or slow 
down the PCI Clock signal. It is used by the 82559 to enable or disable 
suspension of the PCI Clock signal or restart of the PCI clock. When 
the Clockrun signal is not used, this pin should be connected to an 
external pull-down resistor. 





RST# 


Reset. The PCI Reset signal is used to place PCI registers, 
sequencers, and signals into a consistent state. When RST# is 
asserted, all PCI output signals will be tri-stated. 





PME# 
(PCl) 


O/D 


Power Management Event. The Power Management Event signal 
indicates that a power management event has occurred in a PCI bus 
system. 





CSTSCHG 


(CardBus)/ 
WOL (PCI) 


OUT 


Card Status Change/Wake on LAN. This pin is multiplexed to 
provide Card Status Change or Wake on LAN signals. In a CardBus 
system, it is used as the Card Status Change output signal and is an 
asynchronous signal to the Clock signal. It indicates that a power 
management event has occurred in a CardBus system. In a PCI 
system, it is used as the WOL pin and provides a positive pulse of 
approximately 52 ms upon detection of an incoming Magic Packet’. 





ISOLATE# 


Isolate. The Isolate signal is used to isolate the 82559 from the PCI 
bus. When Isolate is active (low), the 82559 does not drive its PCI 
outputs (except PME# and CSTSCHG) or sample its PCI inputs 
(including CLK and RST#). If the 82559 is not powered by an auxiliary 
power source, the ISOLATE# pin must be pulled high through a 10 KQ 
resistor. 





ALTRST# 


Alternate Reset. The Alternate Reset signal is used to reset the 
82559 on power-up. In systems that support an auxiliary power supply, 
ALTRST# should be connected to a power-up detection circuit. 
Otherwise, ALTRST# should be tied to Vcc. 





VIO 











Voltage Input/Output. The VIO pin is the voltage bias pin and is 
typically connected to +5 V in a PCI bus system and +3.3 Vina 
CardBus system. 





Local Memory Interface Signals 























Symbol Type Name and Function 
’ Flash/Modem Data Input/Output. These pins are used for Flash/ 
PED Aal vs Modem data interface. 
Flash Address[16]/25 MHz Clock. This multiplexed pin is controlled 
FLA[16]/ OUT by the status of the Flash Address[7] (FLA[7]) pin. If FLA[7] is left 
CLK25 floating, this pin is used as FLA[16]; otherwise, if FLA[7] is connected 
to a pull-up resistor, this pin is used as a 25 MHz clock. 
Flash Address[15]/EEPROM Data Output. During Flash accesses, 
FLA[15]/ OUT this multiplexed pin acts as the Flash Address [15] output signal. 
EESK During EEPROM accesses, it acts as the serial shift clock output to 


the EEPROM. 
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Symbol Type Name and Function 
Flash Address[14]/EEPROM Data Output. During Flash accesses, 
FLA[14]/ IN/OUT this multiplexed pin acts as the Flash Address [14] output signal. 
EEDO During EEPROM accesses, it acts as serial input data to the EEPROM 
Data Output signal. 
Flash Address[13]/EEPROM Data Input. During Flash accesses, 
FLA[13]/ OUT this multiplexed pin acts as the Flash Address [13] output signal. 
EEDI During EEPROM accesses, it acts as serial output data to the 
EEPROM Data Input signal. 
Flash Address[12]/Modem Central Site Mode. This multiplexed pin 
FLA[12)/ OUT acts as the Flash Address[12] output signal in a non-modem card. If 
MCNTSM# oD modem is enabled, it is used as an output signal to the modem. It is 
either floated by default or driven low by the Modem System Control 
Registers. 
FLA[11)/ Flash Address[11]/Modem Interrupt. This multiplexed pin acts as 
MINT IN/OUT | the Flash Address[1 1] output signal ina non-modem card. If modem is 
enabled, it is used as the Modem Interrupt input signal. 
FLA[10]/ Flash Address[10]/Modem Ring. This multiplexed pin acts as the 
MRING# IN/OUT | Flash Address[10] output signal in a non-modem card. If modem is 
enabled, it is used as the Modem Ring input signal. 
FLA[Q)/ Flash Address[9]/Modem Reset. This multiplexed pin acts as the 
MRST OUT Flash Address[9] output signal in a non-modem card. If modem is 
enabled, it acts as the Modem Reset signal with an active high output. 
Flash Address[8]/ISA Input/Output Channel Ready. This 
FLA[8}/ IN/OUT multiplexed pin acts as the Flash Address[8] output signal in a non- 
IOCHRDY modem card. If modem is enabled, it is used as the ISA IOCHRDY 
input signal. 
Flash Address[7]/Clock Enable. This is a multiplexed pin and acts 
as the Flash Address[7] output signal during nominal operation. When 
FLA[7]/ TS the PCI RST# signal is active, this pin acts as input control over the 
CLKEN FLA[16]/CLK25 output signal. If the FLA[7]/CLKEN pin is connected to 
a pull-up resistor (3.3 KQ), a 25 MHz clock signal is provided on the 
FLA[16]/CLK25 output; otherwise, it is used as FLA[16] output. 
Flash Address[6:2]. These pins are used as Flash address outputs 
FLA[6:2] OUT to support 128 Kbyte Flash addressing. If the modem is enabled, 
these pins carry modem address bits 6:2. 
Flash Address[1]/Auxiliary Power. This multiplexed pin acts as the 
Flash Address[1] output signal during nominal operation. If the modem 
FLA[1]/ is enabled, this pin carries modem address bit 1. When RST is active 
AUXPWR T/S (low), it acts as the power supply indicator. If the 82559 is fed PCI 
power, this pin should be connected to a pull-down resistor; if the 
82559 is fed by auxiliary power, this pin should be connected to a pull- 
up resistor. 
Flash Address [0]/PCI Mode. This multiplexed pin acts as the Flash 
Address[0] output signal during nominal operation. If the modem is 
FLA[O)/ TS enabled, this pin carries modem address bit 0. When RST# is active 
PCIMODE# (low), it acts as the input system type. If the 82559 is used ina 
CardBus system, this pin should be connected to a pull-up resistor 
(3.3 KQ); otherwise, the 82559 considers the host as a PCI system. 
EECS OUT EEPROM Chip Select. The EEPROM Chip Select signal is used to 
assert chip select to the serial EEPROM. 
Flash Chip Select/Address Enable. The Flash Chip Select signal is 
FLCS#/AEN | OUT active during Flash. In modem mode, it acts as an ISA-like Address 








Enable signal (modem chip select). 
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Symbol 


FLOE# 


Type 


OUT 


Name and Function 


Flash Output Enable. This pin provides an active low output enable 
control (read) to the Flash memory. If the modem is enabled, this is an 
active-low output enable (read) of the modem. 





FLWE# 


OUT 


Flash Write Enable. This pin provides an active low write enable 
control to the Flash memory. If the modem is enabled, this is an active 
low write-enable to the modem. 





CFCS# 


OUT 


Security ASIC Chip Select. This pin provides an active low function 
enable to enable/disable Flash memory in Combo designs. This signal 
is asserted high to enable Flash memory in LAN/modem designs. If 
this signal is asserted low, the modem device is enabled, and local bus 
signals are defined for modem. This pin is controlled by setting/ 
clearing the Boot Enable bit in the BootROM BAR. This bit is set 
following a PCI reset enabling external Flash. 








CFCLK 





OUT 





Security ASIC Clock. This pin provides a clock out to a companion 
ASIC residing on the local bus. This pin should be left unconnected in 
designs that do not utilize a companion ASIC on the Flash interface. 
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System Management Bus (SMB) Interface Signals 























Symbol Type Name and Function 

IN Alert Bus Data. This signal is stable when the Alert Bus Clock signal 
SMBD is high. This open drain signal should be pulled high to Vcc in all 

o/D cases. 

IN Alert Bus Clock. This pin is used for the Alert Bus Clock signal. One 
SMBCLK clock pulse is generated for each data bit transferred. It is an open 

O/D drain signal and should be pulled high to Vcc in all cases. 

Bus Alert. The Bus Alert pin is used as an interrupt signal for a slave 

SMBALRT#_ | O/D device on the Alert Bus. It is an open drain signal and should be pulled 


high to Vcc¢ in all cases. 








Testability Port Signals 




















Symbol Type Name and Function 

Test Port. If this input pin is high, the 82559 will enable the test port. 

TEST IN During nominal operation this pin should be connected to a pull-down 
resistor. 

TCK IN Test Port Clock. This pin is used for the Test Port Clock signal. 

TI IN Test Port Data Input. This pin is used for the Test Port Data Input 
signal. 

TEXEC IN Test Port Execute Enable. This pin is used for the Test Port Execute 
Enable signal. 

TO OUT Test Port Data Output. This pin is used for the Test Port Data Output 











signal. 








PHY Signals 





Symbol 


Type 


Name and Function 





x1 


All 


Crystal Input One. X1 and X2 can be driven by an external 3.3 V 25 
MHz crystal. Otherwise, X1 may be driven by an external metal-oxide 
semiconductor (MOS) level 25 MHz oscillator when X2 is left floating. 





X2 


A/O 


Crystal Input Two. X1 and X2 can be driven by an external 3.3 V 25 
MHz crystal. Otherwise, X1 may be driven by an external MOS level 
25 MHz oscillator when X2 is left floating. 





TDP 
TDN 


A/O 


Analog Twisted Pair Ethernet Transmit Differential Pair. These 
pins transmit the serial bit stream for transmission on the Unshielded 
Twisted Pair (UTP) cable. The current-driven differential driver can be 
two-level (10BASE-T) or three-level (100BASE-TX) signals depending 
on the mode of operation. These signals interface directly with an 
isolation transformer. 








RDP 
RDN 





All 





Analog Twisted Pair Ethernet Receive Differential Pair. These 
pins receive the serial bit stream from the isolation transformer. The bit 
stream can be two-level (10BASE-T) or three-level (100BASE-TX) 
signals depending on the mode of operation. 
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Symbol Type Name and Function 


Activity LED. The Activity LED pin indicates either transmit or receive 
activity. When activity is present, the activity LED is on; when no 
ACTLED# OUT activity is present, the activity LED is off. 

In Wake on LAN mode, the ACTLED# signal is used to indicate that 
the received frame passed MAC address filtering. 





Link Integrity LED. The Link Integrity LED pin indicates link integrity. 
LILED# OUT If the link is valid in either 10 or 100 Mbps, the LED is on; if link is 
invalid, the LED is off. 


Speed LED. The Speed LED pin indicates the speed. The speed LED 
will be on at 100 Mbps and off at 10 Mbps. 





SPEEDLED# | OUT 





Reference Bias Resistor (100 Mbps). This pin should be connected 
nbineriy e to a 619 Q pull-down resistor.2 





Reference Bias Resistor (10 Mbps). This pin should be connected 
nbn e to a 549 Q pull-down resistor.° 





Voltage Reference. This pin is connected to a 1.25 V + 1% external 
voltage reference generator. To use the internal voltage reference 
VREF B source, this pin should be left floating. Under normal circumstances, 
the internal voltage reference should be used and this pin would be left 
open. 

















a. 619 Q for RBIAS 100 is only a recommended value and should be fine tuned for various designs. 
b. 549 Q for RBIAS 10 is only a recommended value and should be fine tuned for various designs. 
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82559 Media Access Control Functional Description 





4.1 


Datasheet 


82559 Initialization 


The 82559 has four sources for initialization. They are listed according to their precedence: 
1. ALTRST# Signal 
2. PCI RST# Signal 
3. Software Reset (Software Command) 


4. Selective Reset (Software Command) 


Initialization Effects on 82559 Units 


The following table shows the effect of each of the different initialization sources on major portions 
of the 82559. The initialization sources are listed in order of precedence. For example, any resource 
that is initialized by the Software Reset is also initialized by the D3 to DO transition and ALTRST# 
and PCI RST# but not necessarily by the selective reset. 





























D3 to DO | Software | Selective 
ALTRST# | PCI RST# | ISOLATE# Transition Reset Reset 
EEPROM read and x Xx x _ _ _ 
initialization 
Loadable microcode 
decoded/reset a s x A : 
MAG configuration reset and X x x x x . 
multicast hash 
Memory pointers and Xx Xx x x x 
mircomachine state reset 
PCI Configuration register Xx x xX x _ _ 
reset 
PHY configuration reset X Xx 
Clear only 

Power management event ie 
aa 9 X auxiliary o ts - 

power 

present 
Statistic counters reset X xX -- x xX -- 
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4.1.2 


4.2 


4.2.1 


4.2.1.1 
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Initialization Effects on TCO Functionality 


The 82559 has the ability to be controlled by two masters, the host CPU on the PCI bus and the 
TCO controller on the SMB. The 82559 may be initialized by the PCI bus during SMB operation. 
The table below summarizes the effect of those sources: 





Status and Receive 


Initialization Source SMB Behavior Enable 





ALTRST#, PCI RST#, or 


ISOLATE#? The SMB is terminated instantaneously.° Initialized to inactive 





The SMB cycle is aborted. During SMB read 
commands, the 82559 transfers zeros until the end of 
the cycle. An SMB write cycle has no effect on the 
D3 to DO transition 82559. The 82559 asserts the SMBALRT# after a D3 | Initialized to inactive 
to DO transition. The 82559 indicates its initialization 
status to the TCO controller via an active initialization 
bit in the Status word. 


The SMB cycle is aborted. During SMB read 
commands, the 82559 transfers zeros until the end of 
the cycle. An SMB write cycle has no affect on the 
82559. After a software reset, the 82559 reports its 
initialization in the same manner as in a D3 to DO 
transition. 





Software Reset, 
Selective Reset, or D3 to 
DO transition 


Unaffected 

















a. ISOLATE# acts as reset on its trailing edge. While the 82559 is in the D3 power state, the PCI RST# initializes the 82559 
on the trailing edge. 
b. SMB commands in process will be terminated immediately. 


PCI and CardBus Interface 


82559 Bus Operations 


After configuration, the 82559 is ready for its normal operation. As a Fast Ethernet Controller, the 
role of the 82559 is to access transmitted data or deposit received data. In both cases the 82559, as 
a bus master device, will initiate memory cycles via the PCI bus to fetch or deposit the required 
data. 


In order to perform these actions, the 82559 is controlled and examined by the CPU via its control 
and status structures and registers. Some of these control and status structures reside in the 82559 
and some reside in system memory. For access to the 82559’s Control/Status Registers (CSR), the 
82559 acts as a slave (in other words, a target device). The 82559 serves as a slave also while the 
CPU accesses its 128 Kbyte Flash buffer or its EEPROM. When the 82559 is in modem mode, it 
also acts as a slave. Details regarding modem interface are described in Section 4.6, “Parallel Flash/ 
Modem Interface” on page 33. 


Section 4.2.1.1, “82559 Bus Slave Operation” describes the 82559 slave operation. It is followed 


by a description of the 82559 operation as a bus master (initiator) in Section 4.2.1.2, “82559 Bus 
Master Operation” on page 22. 


82559 Bus Slave Operation 


The 82559 serves as a target device in one of the following cases: 


© CPU accesses to the 82559 System Control Block (SCB) Control/Status Registers (CSR) 
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CPU accesses to the EEPROM through its CSR 
CPU accesses to the 82559 PORT address via the CSR 
CPU accesses to the MDI control register in the CSR 


CPU accesses to the Flash control register in the CSR 
CPU accesses to the 128 Kbyte Flash 





The CSR and the | Mbyte Flash buffer are considered by the 82559 as two totally separated 
memory spaces. The 82559 provides separate Base Address Registers (BARs) in the configuration 
space to distinguish between them. The size of the CSR memory space is 4 Kbyte in the memory 
space and 64 bytes in the I/O space. The 82559 treats accesses to these memory spaces differently. 


4.2.1.1.1 


Control/Status Register (CSR) Accesses 


The 82559 supports zero wait state single cycle memory or I/O mapped accesses to its CSR space. 
Separate BARs request 4 Kbytes of memory space and 64 bytes of I/O space to accomplish this. 
Based on its needs, the software driver will use either memory or I/O mapping to access these 
registers. The 82559 provides 4 valid Kbytes of CSR space, which include the following elements: 


System Control Block (SCB) registers 


PORT register 


Flash control register 


EEPROM control register 


MDI control register 


Flow control registers 


CardBus registers 


The figures below show CSR zero wait state I/O read and write cycles. In the case of accessing the 
Control/Status Registers, the CPU is the initiator and the 82559 is the target of the transaction. 


SYSTEM 


82559 








CLK La ee ea 


FRAME# — i 


C/BE# —{io ro X BE# ) 
IRDY# <> = 
TRDY¥# ~~ O7 
DEVSEL#= ~ >" 
stop# ~~ 7" 




















Figure 2. Conirol/Status Register I/O Read Cycle 
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Read Accesses: The CPU, as the initiator, drives address lines AD[31:0], the command and byte 
enable lines C/BE#[3:0] and the control lines IRDY# and FRAME#. As a slave, the 82559 controls 
the TRDY# signal and provides valid data on each data access. The 82559 allows the CPU to issue 
only one read cycle when it accesses the Control/Status Registers, generating a disconnect by 
asserting the STOP# signal. The CPU can insert wait states by de-asserting IRDY# when it is not 
ready. 
































-- CLK fg ee Se ee 
z FRAME# —— / 
- AD —(nook)( bara ) 

C/BE#  —(vowaX Bee 

— IRDY# v Ls 

r- TRDY# ~~ Ge ) 
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\_ STOP# — Ca 


Figure 3. Conitrol/Status Register I/O Write Cycle 


Write Accesses: The CPU, as the initiator, drives the address lines AD[31:0], the command and 
byte enable lines C/BE#[3:0] and the control lines IRDY# and FRAME#. It also provides the 
82559 with valid data on each data access immediately after asserting IRDY#. The 82559 controls 
the TRDY# signal and asserts it from the data access. The 82559 allows the CPU to issue only one 
I/O write cycle to the Control/Status Registers, generating a disconnect by asserting the STOP# 
signal. This is true for both memory mapped and I/O mapped accesses. 
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4.2.1.1.2 Flash Buffer Accesses 


The CPU accesses to the Flash buffer are very slow. For this reason the 82559 issues a target- 
disconnect at the first data access. The 82559 asserts the STOP# signal to indicate a target- 
disconnect. The figures below illustrate memory CPU read and write accesses to the 128 Kbyte 
Flash buffer. The longest burst cycle to the Flash buffer contains one data access only. 


SYSTEM 


82559 
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Figure 4. Flash Buffer Read Cycle 
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Read Accesses: The CPU, as the initiator, drives the address lines AD[31:0], the command and 
byte enable lines C/BE#[3:0] and the control lines IRDY# and FRAME#. The 82559 controls the 
TRDY# signal and de-asserts it for a certain number of clocks until valid data can be read from the 
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Flash buffer. When TRDY# is asserted, the 82559 drives valid data on the AD[31:0] lines. The 
CPU can also insert wait states by de-asserting IRDY# until it is ready. Flash buffer read accesses 
can be byte or word length. 
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Figure 5. Flash Buffer Write Cycle 


Write Accesses: The CPU, as the initiator, drives the address lines AD[31:0], the command and 
byte enable lines C/BE#[3:0] and the control lines IRDY# and FRAME#. It also provides the 82559 
with valid data immediately after asserting IRDY#. The 82559 controls the TRDY# signal and de- 
asserts it for a certain number of clocks until valid data is written to the Flash buffer. By asserting 
TRDY#, the 82559 signals the CPU that the current data access has completed. Flash buffer write 
accesses can be byte length only. 


4.2.1.1.3 Retry Premature Accesses 


The 82559 responds with a Retry to any configuration cycle accessing the 82559 before the 
completion of the automatic read of the EEPROM. The 82559 may continue to Retry any 
configuration accesses until the EEPROM read is complete. The 82559 does not enforce the rule 
that the retried master must attempt to access the same address again in order to complete any 
delayed transaction. Any master access to the 82559 after the completion of the EEPROM read will 
be honored. Figure 6 below depicts how a Retry looks when it occurs. 
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Figure 6. 


Note: 


Note: 
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PCI Retry Cycle 
The 82559 is considered the target in the above diagram; thus, TRDY# is not asserted. 


A Retry may also occur in the following two scenarios: 
* Card Information Structure (CIS) in memory is accessed in CardBus mode. 


¢ External modem registers are accessed and the modem does not assert IOCHRDY within 7 
PCI clocks from the assertion of MDMCS#. 


4.2.1.1.4 Error Handling 


Data Parity Errors: The 82559 checks for data parity errors while it is the target of the 
transaction. If an error was detected, the 82559 always sets the Detected Parity Error bit in the PCI 
Configuration Status register, bit 15. The 82559 also asserts PERR#, if the Parity Error Response 
bit is set (PCI Configuration Command register, bit 6). The 82559 does not attempt to terminate a 
cycle in which a parity error was detected. This gives the initiator the option of recovery. 


Target-Disconnect: The 82559 prematurely terminate a cycle in the following cases: 
¢ After accesses to the Flash buffer 
e After accesses to its CSR 


e After accesses to the configuration space 


System Error: The 82559 reports parity error during the address phase using the SERR# pin. If the 
SERR# Enable bit in the PCI Configuration Command register or the Parity Error Response bit are 
not set, the 82559 only sets the Detected Parity Error bit (PCI Configuration Status register, bit 15). 
If SERR# Enable and Parity Error Response bits are both set, the 82559 sets the Signaled System 
Error bit (PCI Configuration Status register, bit 14) as well as the Detected Parity Error bit and 
asserts SERR# for one clock. 


The 82559, when detecting system error, will claim the cycle if it was the target of the transaction 
and continue the transaction as if the address was correct. 


The 82559 will report a system error for any parity error during an address phase, whether or not it 
is involved in the current transaction. 
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4.2.1.2 
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82559 Bus Master Operation 


As a PCI Bus Master, the 82559 initiates memory cycles to fetch data for transmission or deposit 
received data and for accessing the memory resident control structures. The 82559 performs zero 
wait state burst read and write cycles to the host main memory. Figure 7 and Figure 8 depict 

memory read and write burst cycles. For bus master cycles, the 82559 is the initiator and the host 
main memory (or the PCI host bridge, depending on the configuration of the system) is the target. 
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Figure 7. Memory Read Burst Cycle 
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Figure 8. Memory Write Burst Cycle 


The CPU provides the 82559 with action commands and pointers to the data buffers that reside in 
host main memory. The 82559 independently manages these structures and initiates burst memory 
cycles to transfer data to and from them. The 82559 uses the Memory Read Multiple (MR 
Multiple) command for burst accesses to data buffers and the Memory Read Line (MR Line) 
command for burst accesses to control structures. For all write accesses to the control structure, the 
82559 uses the Memory Write (MW) command. For write accesses to data structure, the 82559 
may use either the Memory Write or Memory Write and Invalidate (MWI) commands. 
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Read Accesses: The 82559 performs block transfers from host system memory in order to perform 
frame transmission on the serial link. In this case, the 82559 initiates zero wait state memory read 
burst cycles for these accesses. The length of a burst is bounded by the system and the 82559’s 
internal FIFO. The length of a read burst may also be bounded by the value of the Transmit DMA 
Maximum Byte Count in the Configure command. The Transmit DMA Maximum Byte Count 
value indicates the maximum number of transmit DMA PCI cycles that will be completed after an 
82559 internal arbitration. (Details on the Configure command are described in the 10/100 Mbit 
Family Software Developer’s Manual.) 


The 82559, as the initiator, drives the address lines AD[31:0], the command and byte enable lines 
C/BE#[3:0] and the control lines IRDY# and FRAME#. The 82559 asserts IRDY# to support zero 
wait state burst cycles. The target signals the 82559 that valid data is ready to be read by asserting 
the TRDY# signal. 


Write Accesses: The 82559 performs block transfers to host system memory during frame 
reception. In this case, the 82559 initiates memory write burst cycles to deposit the data, usually 
without wait states. The length of a burst is bounded by the system and the 82559’s internal FIFO 
threshold. The length of a write burst may also be bounded by the value of the Receive DMA 
Maximum Byte Count in the Configure command. The Receive DMA Maximum Byte Count value 
indicates the maximum number of receive DMA PCI transfers that will be completed before the 
82559 internal arbitration. (Details on the Configure command are described in the 10//00Mbit 
Family Software Developer’s Manual.) 


The 82559, as the initiator, drives the address lines AD[31:0], the command and byte enable lines 
C/BE#[3:0] and the control lines IRDY# and FRAME#. The 82559 asserts IRDY# to support zero 
wait state burst cycles. The 82559 also drives valid data on AD[31:0] lines during each data phase 
(from the first clock and on). The target controls the length and signals completion of a data phase 
by de-assertion and assertion of TRDY#. 


Cycle Completion: The 82559 completes (terminates) its initiated memory burst cycles in the 
following cases: 


¢ Normal Completion: All transaction data has been transferred to or from the target device (for 
example, host main memory). 


¢ Backoff: Latency Timer has expired and the bus grant signal (GNT#) was removed from the 
82559 by the arbiter, indicating that the 82559 has been preempted by another bus master. 


¢ Transmit or Receive DMA Maximum Byte Count: The 82559 burst has reached the length 
specified in the Transmit or Receive DMA Maximum Byte Count field in the Configure 
command block. (Details relating to this field and the Configure command are described in the 
10/100 Mbit Family Software Developer’s Manual.) 


¢ Target Termination: The target may request to terminate the transaction with a target- 
disconnect, target-retry, or target-abort. In the first two cases, the 82559 initiates the cycle 
again. In the case of a target-abort, the 82559 sets the Received Target-Abort bit in the PCI 
Configuration Status field (PCI Configuration Status register, bit 12) and does not re-initiate 
the cycle. 


¢ Master Abort: The target of the transaction has not responded to the address initiated by the 
82559 (in other words, DEVSEL+# has not been asserted). The 82559 simply de-asserts 
FRAME+# and IRDY# as in the case of normal completion. 


¢ Error Condition: In the event of parity or any other system error detection, the 82559 
completes its current initiated transaction. Any further action taken by the 82559 depends on 
the type of error and other conditions. 
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4.2.1.2.1_ Memory Write and Invalidate 


The 82559 has four Direct Memory Access (DMA) channels. Of these four channels, the Receive 
DMA is used to deposit the large number of data bytes received from the link into system memory. 
The Receive DMA uses both the Memory Write (MW) and the Memory Write and Invalidate 
(MWYI) commands. In order to use MWI, the 82559 must guarantee the following: 


1. Minimum transfer of one cache line 
2. Active byte enable bits (or BE#[3:0] are all low) during MWI access 


3. The 82559 may cross the cache line boundary only if it intends to transfer the next cache line 
too. 
In order to ensure the above conditions, the 82559 may use the MWI command only if the 
following conditions hold: 


1. The Cache Line Size (CLS) written in the CLS register during PCI configuration is 8 or 16 
Dwords. 


. The accessed address is cache line aligned. 

. The 82559 has at least 8 or 16 Dwords of data in its receive FIFO. 

. There are at least 8 or 16 Dwords of data space left in the system memory buffer. 

. The MWI Enable bit in the PCI Configuration Command register, bit 4, should is set to 1b. 


. The MWI Enable bit in the 82559 Configure command should is set to 1b. (Details on the 
Configure command are described in the 10/100 Mbit Family Software Developer’s Manual.) 


Nn nn FW WN 


If any one of the above conditions does not hold, the 82559 will use the MW command. If a MWI 
cycle has started and one of the conditions is no longer valid (for example, the data space in the 
memory buffer is now less than CLS), then the 82559 terminates the MWI cycle at the end of the 
cache line. The next cycle will be either a MW or MWI cycle depending on the conditions listed 
above. 


If the 82559 started a MW cycle and reached a cache line boundary, it either continues or 
terminates the cycle depending on the Terminate Write on Cache Line configuration bit of the 
82559 Configure command (byte 3, bit 3). If this bit is set, the 82559 terminates the MW cycle and 
attempts to start a new cycle. The new cycle is a MWI cycle if this bit is set and all of the above 
listed conditions are met. If the bit is not set, the 82559 continues the MW cycle across the cache 
line boundary if required. (Details on the Configure command are described in the 10/100 Mbit 
Family Software Developer’s Manual.) 


4.2.1.2.2 Read Align 


The Read Align feature enhances the 82559’s performance in cache line oriented systems. In these 
particular systems, starting a PCI transaction on a non-cache line aligned address may cause low 
performance. 


In order to resolve this performance anomaly, the 82559 attempts to terminate transmit DMA 
cycles on a cache line boundary and start the next transaction on a cache line aligned address. This 
feature is enabled when the Read Align Enable bit is set in the 82559 Configure command (byte 3, 
bit 2). (Details on the Configure command are described in the 10/100 Mbit Family Software 
Developer’s Manual.) 


If this bit is set, the 82559 operates as follows: 
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© When the 82559 is almost out of resources on the transmit DMA (that is, the transmit FIFO is 
almost full), it attempts to terminate the read transaction on the nearest cache line boundary 
when possible. 


© When the arbitration counter’s feature is enabled (in other words, the Transmit DMA 
Maximum Byte Count value is set in the Configure command), the 82559 switches to other 
pending DMAs on cache line boundary only. 


Note the following: 


¢ This feature is not recommended for use in non-cache line oriented systems since it may cause 
shorter bursts and lower performance. 


¢ This feature should be used only when the CLS register in PCI Configuration space is set to 8 
or 16. 


¢ The 82559 reads all control data structures (including Receive Buffer Descriptors) from the 
first Dword (even if it is not required) in order to maintain cache line alignment. 


4.2.1.2.3 Error Handling 


Data Parity Errors: As an initiator, the 82559 checks and detects data parity errors that occur 
during a transaction. If the Parity Error Response bit is set (PCI Configuration Command register, 
bit 6), the 82559 also asserts PERR# and sets the Data Parity Detected bit (PCI Configuration 
Status register, bit 8). In addition, if the error was detected by the 82559 during read cycles, it sets 
the Detected Parity Error bit (PCI Configuration Status register, bit 15). 


4.2.2 PCI Mode Pin 


During PCI reset the 82559 samples the PCIMODE# (multiplexed with FLAO) input signal to 
determine the nature of the host system. If the PCIMODE# signal is sampled low when RST# is 
active, the host system bus is a PCI system. If PCIMODE# is sampled high during reset, the host 
system is a CardBus system. In a CardBus system, the PCIMODE# pin should be connected to a 
pull-up resistor; otherwise, the 82559 assumes it is a PCI system. 


4.2.3 Clockrun Signal 


The CLKRUN# signal is used to control the PCI clock as defined in the CardBus specification and 
PCI Mobile design guide and is compliant with both the CardBus specification and PCI Mobile 
design guide. This signal is active in both the CardBus and PCI bus operating modes. The Clockrun 
signal is an open drain I/O signal. It is used as a bidirectional channel between the host and the 
devices. 


¢ The host de-asserts the CLKRUN# signal to indicate that the clock is about to be stopped or 
slowed down to a non-operational frequency. 


¢ The host asserts the CLKRUN# signal when the interface clock is either running at a normal 
operating frequency or about to be started. 


¢ The 82559 asserts the CLKRUN# signal to indicate that it needs the PCI clock to prevent the 
host from stopping the PCI clock or to request that the host restore the clock if it was 
previously stopped. 


Proper operation requires that the system latency from the nominal PCI CLK to CLKRUN# 


assertion should be less than 0.5 us. If the system latency is longer than 0.5 Us, the occurrence of 
receive overruns increases. For use in these types of systems, the Clockrun functionality should be 
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disabled (Section 9.1.12, “General Control Register” on page 76). In this case, the 82559 will claim 
the PCI clock even during idle time. If the CLKRUN# signal is not used, it should be connected to 
a pull-down resistor. 


Power Management Event and Card Status Change Signals 


The 82559 supports power management indications in both the PCI and CardBus mode. In 
CardBus systems, the CSTSCHG pin is used for power management event indication. The PME# 
output pin provides an indication of a power management event in PCI systems. The CSTSCHG 
pin is supported by four registers located in the Control/Status Register (Section 9.0, “Control/ 
Status Registers” on page 71 describes these registers in more detail): 


¢ Event Register 
¢ Mask Register 
¢ Present State Register 


¢ Force Event Register 


PCI Power Management 


In addition to the base functionality of the 82558 B-step, the 82559 supports a larger set of wake-up 
packets and the capability to wake the system on a link status change from a low power state. These 
added power management enhancements enable the 82559 to adhere to emerging standards. The 
82559 enables the host system to be in a sleep state and remain virtually connected to the network. 
After a power management event or link status change is detected, the 82559 will wake the host 
system. The sections below describe these events, the 82559 power states, and estimated power 
consumption at each power state. 


Power States 


The 82559 contains two sets of power management registers, one for PCI and one for CardBus, and 
implements all four power states as defined in the Power Management Network Device Class 
Reference Specification, Revision 1.0. The four states, DO through D3, vary from maximum power 
consumption at DO to the minimum power consumption at D3. PCI transactions are only allowed in 
the DO state, except for host accesses to the 82559’s PCI configuration registers. The D1 and D2 
power management states enable intermediate power savings while providing the system wake-up 
capabilities. In the D3.) state, the 82559 can provide wake-up capabilities only if auxiliary power 
is supplied. Wake-up indications from the 82559 are provided by the Power Management Event 
(PME#) signal in PCI implementations and the Card Status Change (CSTSCHG) signal in CardBus 
designs. 


In addition to providing a host interface through the PCI bus, the 82559 provides TCO controller 
access through a dedicated System Management Bus (SMB). Additional information on the 
supported TCO functionality at all power states is described in Section 7.0, “82559 TCO 
Functionality” on page 51. 
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DO Power State 


As defined in the Network Device Class Reference Specification, the device is fully functional in 
the DO power state. In this state, the 82559 receives full power and should be providing full 
functionality. In the 82559 the DO state is partitioned into two substates, DO Uninitialized (DOu) 
and DO Active (D0a). 


D0Ou is the 82559’s initial power state following a power on reset event and prior to the Base 
Address Registers (BARs) being accessed. While in the DOu state, the 82559 has PCI slave 
functionality to support its initialization by the host and supports Wake on LAN* mode. 
Initialization of the CSR, Memory, or I/O Base Address Registers in the PCI Configuration space 
switches the 82559 from the DOu state to the D0a state. 


In the D0a state, the 82559 provides its full functionality and consumes its nominal power. In 
addition, the 82559 supports wake on link status change (see Section 4.3.2, “Wake-up Events” on 
page 31). While it is active, the 82559 requires a nominal PCI clock signal (in other words, a clock 
frequency greater than 16 MHz) for proper operation. During idle time, the 82559 supports a PCI 
clock signal suspension using the Clockrun signal mechanism. The 82559 supports a dynamic 
standby mode. In this mode, the 82559 is able to save almost as much power as it does in the static 
power-down states. The transition to or from standby is done dynamically by the 82559 and is 
transparent to the software. 


D1 Power State 


In order for a device to meet the D1 power state requirements, as specified in the Advanced 
Configuration and Power Interface (ACPI) Specification, Revision 1.0, it must not allow bus 
transmission or interrupts; however, bus reception is allowed. Therefore, device context may be lost 
and the 82559 does not initiate any PCI activity. In this state, the 82559 responds only to PCI 
accesses to its configuration space and system wake-up events. 


The 82559 retains link integrity and monitors the link for any wake-up events such as wake-up 
packets or link status change. Following a wake-up event, the 82559 asserts the PME# signal to 
alert the PCI based system or the CSTSCHG signal for a CardBus system. 


D2 Power State 


The ACPI D2 power state is similar in functionality to the D1 power state. If the bus is in the B2 
state, the 82559 will consume less current than it does in the D1 state. In addition to D1 
functionality, the 82559 can provide a lower power mode with wake-on-link status change 
capability. The 82559 may enter this mode if the link is down while the 82559 is in the D2 state. In 
this state, the 82559 monitors the link for a transition from an invalid link to a valid link. The 82559 
will not attempt to keep the link alive by transmitting idle symbols or link integrity pulses. ! The 
sub-10 mA state due to an invalid link can be enabled or disabled by a configuration bit in the 
Power Management Driver Register (PMDR). 


D3 Power State 


In the D3 power state, the 82559 has the same capabilities and consumes the same amount of power 
as it does in the D2 state. However, it enables the PCI system to be in the B3 state. If the PCI 
system is in the B3 state (in other words, no PCI power is present), the 82559 provides wake-up 





1. Fora topology of two 82559 devices connected by a crossed twisted-pair Ethernet cable, the deep power-down mode should be disabled. If 


it is enabled, the two devices may not detect each other if the operating system places them into a low power state before both nodes 
become active. 
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capabilities if it is connected to an auxiliary power source in the system. If PME is disabled, the 
82559 does not provide wake-up capability or maintain link integrity. In this mode the 82559 
consumes its minimal power. 


The 82559 enables a system to be in a sub-5 watt state (low power state) and still be virtually 
connected. More specifically, the 82559 supports full wake-up capabilities while it is in the D3 .o)4 
state. The 82559 can be connected to an auxiliary power source (Vayx), which enables it to provide 
wake-up functionality while the PCI power is off. The typical current consumption of the 82559 is 
125 mA at 3.3 V. Thus, a dual power plane is not required. If connected to an auxiliary power 
source, the 82559 receives all of its power from the auxiliary source in all power states. When 
connected to an auxiliary power supply, the 82559 is required to have a status indicator of whether 
or not the power supply is valid (in other words, auxiliary power is stable). The indication is 
received at the AUXPWR pin, as described next. 


4.3.1.4.1 Auxiliary Power Signal 


The 82559 senses whether it is connected to the PCI power supply or to an auxiliary power supply 
(Vaux) via the FLA1/AUXPWR pin. The auxiliary power detection pin (multiplexed with FLA1) 
is sampled when the PCI RST# or ALTRST# signals are active. An external pull-up resistor should 
be connected to the 82559 if it is fed by Vayx; otherwise, the FLA1/AUXPWR pin should be left 
floating. The presence of AUXPWR affects the value reported in the Power Management 
Capability Register (PCI Configuration Space, offset DEH). The Power Management Capability 
Register is described in more detail in Section 8.1.20, “Power Management Capabilities Register” 
on page 63. 


4.3.1.4.2 Alternate Reset Signal 


The 82559’s ALTRST# input pin functions as a power-on reset input. Following ALTRST# being 
driven low, the 82559 is initialized to a known state. In systems that support auxiliary power, this 
pin should be connected to the auxiliary power’s power stable signal (power good) of the 82559’s 
power source. In a LAN on Motherboard (LOM) solution, this signal is available on the system. In 
network adapter implementations, an external analog device connected to the auxiliary power 
supply can be used to produce this signal. In systems that do not have an auxiliary power source, 
the ALTRST# signal should be tied to a pull-up resistor. 


4.3.1.4.3 Isolate Signal 


When the 82559 is connected to Vay, it may be powered on while the PCI bus is powered off. In 
this case, the 82559 isolates itself from the PCI bus. The 82559 has a dedicated ISOLATE# pin that 
should be connected to the PCI power source’s stable power signal (power good). Whenever the 
PCI Bus is in the B3 state, the PCI power good signal becomes inactive and the 82559 isolates itself 
from the PCI bus. During this state, the 82559 ignores all PCI signals including the RST# and CLK 
signals. It also tristates all PCI outputs, except the PME# signal. In the transition to an active PCI 
power state (in other words, from B3 power state to BO power state), the PCI power good signal 
shifts high. 
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In a LAN on Motherboard solution, the PCI power good signal is supplied by the system. In 
network adapter implementations, the PCI power good signal can be generated locally using an 
external analog device. In these designs, the ISOLATE# signal should “envelope” the system’s PCI 
power good signal as shown in Figure 9. 


PCI power good signal = ff. - = 
Required ISOLATE# 
signal behavior YI), FY 


Isolate Signal Behavior to PCI Power Good Signal 


In many systems, the PCI RST# signal is asserted low whenever the PCI bus is inactive. In these 
systems, the 82559 B-step device and later devices allow the ISOLATE# pin to be driven from the 
PCI RST# signal. In this case, the ALTRST# pin on the 82559 should be pulled high to the PCI bus 
high voltage level. 


4.3.1.4.4 PCI Reset Signal 


The PCI RST# signal may be activated in one of the following cases: 

¢ Power-up 

¢ Warm boot 

¢ Wake-up (B3 to BO transition) 

¢ Set to power-down (BO to B3 transition) 
If PME is enabled (in the PCI power management registers), the RST# signal does not affect any 
PME related circuits (in other words, the CSTSCHG registers (CardBus only), PCI power 
management registers, and the wake-up packet would not be affected). While the RST# signal is 


active, the 82559 ignores other PCI signals and floats its outputs. However, if AUXPWR is 
asserted, the RST# signal has no affect on any circuitry. 


While the 82559 is in the DO, D1, or D2 power state, it is initialized by the RST# level. When the 
82559 is in the D3 power state, the system bus may be in the B3 bus power state. In the B3 power 
state, the PCI RST# signal is undefined; however, the auxiliary power source proposal for the PCI 
Specification, Revision 2.2 is for the PCI RST# signal to be an active low. Therefore, the 82559 
uses the PCI RST# similarly to the ISOLATE# signal in D3 power state. Following the trailing 
edge of the PCI RST#, the 82559 is initialized while preserving the PME# signal and its context. 


According to the PCI specification, during the B3 state, the RST# signal is undefined. 


The transition from the B3 power state to the BO power state occurs on the trailing edge of the 
RST# signal. 


The initialization signal is generated internally in the following cases: 
¢ Active RST# signal while the 82559 is the DO, D1, or D2 power state 
¢ RST# trailing edge while the 82559 is in the D3 power state 
¢ ISOLATE# trailing edge 


29 


82559 — Networking Silicon ] Nn 


30 


The internal initialization signal resets the PCI Configuration Space, MAC configuration, and 
memory structure. 


The behavior of the PCI RST# signal and the internal 82559 initialization signal are shown in the 
figure below. 


DO - D2 power state 


Internal hardware —  -f- fe 
reset 


D3 power state 


PCI RST# 


PCI RST# 


Internal hardware 
reset 640 ns 


Internal reset 


due to ISOLATE# 
ISOLATE# 


Internal hardware 


reset 


| 640 ns | 


Figure 10. 82559 Initialization Upon PCI RST# and ISOLATE# 


The tables below summarizes the 82559’s functionality and power consumption at the different 


power states. 









































Power State Conditions 100 Mbs 10 Mbs 
DO Maximum 175 mA 140 mA 
DO Average (5 Mbps) 125 mA 115 mA 

D : 
Do Vanes 120 mA 55 mA 
(with network load) 
DOu CardBus with PCI CLK <70mA <70mA 
D2/D3 (link PCI CLK 10 mA 10 mA 
down) Without PCI CLK 3mA 3mA 
Dx (x>0 with PCI CLK 10 mA 10 mA 
PME# disabled) | without PCI CLK 3mA 3mA 
WOL Wake on LAN power down <3mA <3mA 











NOTE: All values shown for the D3 state assume the availability of 3.3 V standby available to the device. 
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Power , : . 
State Link 82559 Functionality 
* P i 
DOu Don’t care ia aie 
« PCl slave access 
‘ Full functionality at full power and wake on invalid 
Valid : 
DOa link 
Invalid Full functionality at full power and wake on valid link 
Valid * Wake on “interesting” packets and link invalid 
- * PCl configuration access 
. * Wake on link valid 
Invalid . . 
« PCl configuration access 
op Valid Same functionality as D1 (link valid) 
Invalid Detection for valid link and no link integrity 
D3 (with Valid Same functionality as D1 (link valid) 
power) Invalid Detection for valid link and no link integrity 
No wake-up functionalit 
Dx (x>0 P : f y . 
without Don't Care | Note: If the TCO bit is set in the EEPROM, the 
PME#) 82559 will not disable the link function and will 
consume power as in the D2 state. 
4.3.2 Wake-up Events 


There are two types of wake-up events: “Interesting” Packets and Link Status Change. These two 
events are detailed below. 


Note: The wake-up event is supported only if the PME Enable bit in the Power Management Control/ 
Status (PMCSR) register is set. (The PMCSR is described in Section 8.1.21, “Power Management 
Control/Status Register (PMCSR)” on page 64.) 


4.3.2.1 “Interesting” Packet Event 


In the power-down state, the 82559 is capable of recognizing “interesting” packets. The 82559 
supports pre-defined and programmable packets that can be defined as any of the following: 


¢ ARP Packets (with Multiple IP addresses) 

¢ Direct Packets (with or without type qualification) 

° Magic Packet* 

¢ Neighbor Discovery Multicast Address Packet (‘ARP’ in IPv6 environment) 
¢ NetBIOS over TCP/IP (NBT) Query Packet (under IPv4) 

¢ Internetwork Package Exchange* (IPX) Diagnostic Packet 

¢ TCO Packet 


This allows the 82559 to handle various packet types. In general, the 82559 supports 
programmable filtering of any packet in the first 128 bytes. 
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When the 82559 is in one of the low power states, it searches for a predefined pattern in the first 
128 bytes of the incoming packets. The only exception is the Magic Packet, which is scanned for 
the entire frame. The 82559 will classify the incoming packets as one of the following categories: 


¢ No Match. The 82559 discards the packet and continues to process the incoming packets. 


¢ TCO Packet. The 82559 implements perfect filtering of TCO packets. After a TCO packet is 
processed, the 82559 is ready for the next incoming packet. There are two possible system 
environments: 


— TCO controller on the SMB. The entire TCO packet is transferred to the TCO controller. 


— System without TCO controller. TCO packets are treated as any other wake-up packet 
and may assert the PME# signal if configured to do so. 


¢ Wake-up Packet. The 82559 is capable of recognizing and storing the first 128 bytes of a 
wake-up packet. If a wake-up packet is larger than 128 bytes, its tail is discarded by the 82559. 
After the system is fully powered-up, software has the ability to determine the cause of the 
wake-up event via the PMDR and dump the stored data to the host memory. 


Magic Packets are an exception. The magic packets may cause a power management event and 
set an indication bit in the PMDR;; however, it is not stored by the 82559 for use by the system 
when it is woken up. 


4.3.2.2 Link Status Change Event 


The 82559 link status indication circuit is capable of issuing a PME on a link status change from a 
valid link to an invalid link condition or vice versa. The 82559 reports a PME link status event in all 
power states. The PME# signal is gated by the PME Enable bit in the PMCSR and the COMA 

Configure command, which is described in the 10/100 Mbit Family Software Developer’s Manual. 


4.4 CardBus Power Management 


The CardBus Power Management Proposal differs from the PCI Power Management Specification 
in the following manner: 


¢ The PME# signal is replaced by CSTSCHG which is an active high output signal. 
¢ An auxiliary power source, Vat, is supplied on the same V,,, pins. 
¢ An auxiliary power source bit in the PMC register must be set. 


¢ The PCI clock signal and the PCI reset signal are guaranteed to be kept low in the B3 state. 


In addition, the 82559 also meets the CardBus requirement for current consumption less than 70 
mA in the DOu state. 


4.5 Wake on LAN (Preboot Wake-up) 


When the 82559 is drawing power from an auxiliary power source (Vax), it can support the same 
preboot Wake on LAN (WOL) capabilities as the 82558 device. The 82559 enters WOL mode after 
the following events occur: 


¢ An ALTRST# is completed. 
¢ The 82559 reads the EEPROM and the WOL bit is set. 
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When the 82559 is in WOL mode: 


¢ The 82559 scans incoming packets for a Magic Packet. When it receives a Magic packet, the 
82559 asserts the PME# signal (until cleared) and the CSTSCHG signal for 52 ms. 


¢ The Activity LED changes its functionality to indicates that the received frame passed 
Individual Address (IA) filtering or broadcast filtering. 


¢ The PCI Configuration registers are accessible to the host. 


¢ Software should not attempt to access the Flash. 


The 82559 switches from WOL mode to the DOa power state following a setup of the Memory or 
I/O Base Address Registers in the PCI Configuration space. While the 82559 is in the DOu, D1, D2, 
or D3 power state, if the 82559 receives a Magic packet, it issues a positive pulse for approximately 
52 ms on the CSTSCHG pin. For PCI systems and in designs that support the 3-pin header 
standard, the CSTSCHG pin acts as the WOL signal. 


Parallel Flash/Modem Interface 


The 82559’s parallel interface is used for Flash interface only or modem interface only. The 82559 
supports a glueless interface to an 8-bit wide, 128 Kbyte, parallel memory device. The parallel 
local port is multiplexed with a modem interface in a LAN/modem combination card. 


The Flash (or boot PROM) is read from or written to whenever the host CPU performs a read or a 
write operation to a memory location that is within the Flash mapping window. All accesses to the 
Flash, except read accesses, require the appropriate command sequence for the device used. (Refer 
to the specific Flash data sheet for more details on reading from or writing to the Flash device.) The 
accesses to the Flash are based on a direct decode of CPU accesses to a memory window defined in 
either the 82559 Flash Base Address Register (PCI Configuration space at offset 18H) or the 
Expansion ROM Base Address Register (PCI Configuration space at offset 30H). The 82559 
asserts control to the Flash when it decodes a valid access. 


The 82559 supports an external Flash memory (or boot PROM) of up to 128 Kbyte. The Expansion 
ROM address can be separately disabled by setting the corresponding bit in the EEPROM, word 
AH. 


Flash accesses must always be assembled or disassembled by the 82559 whenever the access is 
greater than a byte-wide access. Due to slow access times to a typical Flash and to avoid violating 
PCI bus holding specifications (no more than 16 wait states inserted for any cycles that are not 
system initiation cycles), the maximum data size is either one word or one byte for a read operation 
and one byte only for a write operation. 


Serial EEPROM Interface 


The serial EEPROM stores configuration data for the 82559 and is a serial in/serial out device. The 
82559 supports a either a 64 register or 256 register size EEPROM and automatically detects the 
EEPROM’s size. A 256 word EEPROM device is required for a Cardbus system and contains the 
CIS information. A 256 word EEPROM device is also required for a TCO enabled system in order 
to hold the heartbeat packet. The EEPROM should operate at a frequency of at least 1 MHz. 
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All accesses, either read or write, are preceded by a command instruction to the device. The address 
field is six bits for a 64 register EEPROM or eight bits for a 256 register EEPROM. The end of the 
address field is indicated by a dummy zero bit from the EEPROM, which indicates the entire 
address field has been transferred to the device. An EEPROM read instruction waveform is shown 
in the figure below. 


EESK | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 





EECS 





EEDI 


| READ OP code 





EEDO 


Figure 11. 64-word EEPROM Read Instruction Waveform 


The 82559 may also use the EEPROM for heartbeat packet transmission (systems without a TCO 
controller are also supported). In these designs, the EEPROM is accessed through time windows 
autonomously by the 82559 hardware. During these time windows, the 82559 will respond with a 
PCI Retry to both EEPROM and Flash accesses. 


The 82559 performs an automatic read of five words (OH, 1H, 2H, AH, and DH) of the EEPROM 


after the de-assertion of Reset. It may read six more words (BH, CH, FBH, FCH, FDH, and FEH) if 
the modem bit is set in the EEPROM (word AH, bit 0). 
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The 82559 EEPROM format is shown below in Figure 12. 























































































































Word | 15 14 | 13 12 11 10 9 8 7 6 5 4 3 2 1 0 
OH IA Byte 2 IA Byte 1 
1H IA Byte 4 IA Byte 3 
2H IA Byte 6 IA Byte 5 
AH Sig ID | Ob | BD Rev ID ce DPD | WOL 00b WMR Phe MDM 
BH Subsystem ID 
CH Subsystem Vendor ID 
DH 0000b HB Packet Pointer SMB Address Field/EEPROM CIS Pointer 
FBH Modem Vendor ID 
FCH Modem Device ID 
FDH Modem Program Interface (02) Modem Revision Number (00) 
FEH Modem Power Dissipation (DO-D3) Modem Power Consumption (DO-D3) 











Figure 12. 82559 EEPROM Format 


Note that word AH contains several configuration bits. Bits from word AH, FBH through FEH, and 
certain bits from word DH are described as follows: 


Table 1. EEPROM Words Field Descriptions 
































Bits Name Description 

Word Signature The Signature field is a signature of 01b, indicating to the 82559 that there is a 

AH, valid EEPROM present. If the Signature field is not 01b, the other bits are 

15:14 ignored and the default values are used. 

Word ID The ID bit indicates how the Subsystem ID and Subsystem Vendor ID fields are 

AH, 13 used as described in Section 8.1.12, “PCI Subsystem Vendor ID and 
Subsystem ID Registers” on page 61. Default value is Ob. 

Word Reserved This bit is reserved and should be set to Ob. 

AH, 12 

Word Boot Disable The Boot Disable bit disables the Expansion ROM Base Address Register (PCI 

AH, 11 Configuration space, offset 30H) when it is set. Default value is Ob. 

Word Revision ID These three bits are used as the three least significant bits of the device 

AH, revision, if bits 15, 14, and 13 equal 011b and the ID was set as described in 

10:8 Section 8.1.12, “PCI Subsystem Vendor ID and Subsystem ID Registers” on 
page 61. The default value depends on the silicon revision (for example, the 
82559 C-Step’s Revision ID is 09h). 

Word 82559 B-step This bit is reserved and should be set to 1b. 

AH, 7 Fae , ; ; : ; ; : 

82559 C-step This bit is used in conjunction with the Signature field and the ID bit to help 
Alternate ID define the Device ID. When bit 7 equals 1b, the Device ID is 1229H and the 

device is compatible to previous steppings of the 82559. When bit 7 equals Ob, 
the LAN function reports a Device ID of 1029H and the device is not compatible 
with the 82559. Details regarding the 82559 ID programming are described in 
Section 8.1.12, “PCI Subsystem Vendor ID and Subsystem ID Registers” on 
page 61. 
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EEPROM Words Field Descriptions 






































Bits Name Description 

Word Deep Power This bit either enables or disables Deep Power Down in the D2 or D3 states 

AH, 6 Down when PME is disabled: 
‘0’ Deep Power Down is enabled in D3 state if PME-Disabled 
‘1’ Deep Power Down disabled in D3 state when PME-Disabled. 
Note: When using the 82559’s Alert capability, the Deep Power Down capability 
should be disabled. Alert devices will not be able to transmit or receive on the 
SMBus if the device is ina Deep Power Down Mode. 

Word Wake on LAN The WOL bit sets the 82559 into WOL mode. When in this mode the 82559 

AH, 5 reads three additional words from the EEPROM, word addresses 0H, 1H, and 
2H. These words are expected to hold the MAC Individual Address. After 
reading these words the 82559 wakes the system by asserting PME# when a 
wake-up packet is received. Default value is Ob. 

Word Reserved These are reserved and should be set to 00b. 

AH, 4:3 

Word 

AH, 2 

Word Standby Enable The Standby Enable bit enables the 82559 to enter standby mode. When this bit 

AH, 1 equals 1b, the 82559 is able to recognize an idle state and can enter standby 
mode (some internal clocks are stopped for power saving purposes). The 
82559 does not require a PCI clock signal in standby mode. If this bit equals Ob, 
the idle recognition circuit is disabled and the 82559 always remains in an active 
state. Thus, the 82559 will always request PCI CLK using the Clockrun 
mechanism. 

Word Modem If this bit equals Ob, the design is a single function design (LAN function) only. If 

AH, 0 this bit equals 1b, a modem is attached on the 82559 local parallel port. 

Word Heartbeat Packet | This field of bits contains the location of the Heartbeat packet within the 

DH, Pointer EEPROM. The pointers are expressed in a granularity of 16 words. A value of 0 

11:8 is used as a null pointer. 

Word, SMB Address This field of bits is a multiplexed function field. In a PCI system, it acts as an 

DH, 7:0 | Field/EEPROM SMB address field (7-bit field). When this field is used as the SMB address field, 

CIS Pointer bit 7 equals Ob. 

In a CardBus system, this field is used for CIS pointers. When this field is used 
as the EEPROM CIS Pointer, it contains two 4-bit pointers that point to the 
location of the CIS information within the EEPROM. The pointers are expressed 
in a granularity of 16 words. A value of 0 is used as a null pointer. The Ethernet 
CIS pointer resides in bits 3:0 and the modem CIS pointer resides in bits 7:4. 

Words | Modem These word fields hold the modem configuration parameters are loaded to the 

FBH -_ | Configuration PCI Configuration space. A combination LAN/modem card requires a 256-word 

FEH Parameters EEPROM. 











The IA read from the EEPROM is used by the 82559 until an IA Setup command is issued by 
software. The IA defined by the IA Setup command overrides the IA read from the EEPROM. 


10/100 Mbps CSMA/CD Unit 


The 82559 CSMA/CD unit implements both the IEEE 802.3 Ethernet 10 Mbps and IEEE 802.3u 
Fast Ethernet 100 Mbps standards. It performs all the CSMA/CD protocol functions such as 
transmission, reception, collision handling, etc. The 82559 CSMA/CD unit interfaces the internal 
PHY unit through a standard Media Independent Interface (MID, as specified by IEEE 802.3, 
Chapter 22. This is a 10/100 Mbps mode in which the data stream is nibble-wide and the serial 
clocks run at either 25 or 2.5 MHz. 
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Full Duplex 


When operating in full duplex mode the 82559 can transmit and receive frames simultaneously. 
Transmission starts regardless of the state of the internal receive path. Reception starts when the 
internal PHY detects a valid frame on the receive differential pair of the PHY. 


The 82559 operates in either half duplex mode or full duplex mode. For proper operation, both the 
82559 CSMA/CD module and the PHY unit must be set to the same duplex mode. The CSMA 
duplex mode is set by the 82559 Configure command or forced by automatically tracking the mode 
in the PHY unit. 


The PHY duplex mode is set either by Auto-Negotiation or, if Auto-Negotiation is disabled, by 
setting the full duplex bit in the Management Data Interface (MDP) Register 0, bit 8. By default, the 
internal PHY unit advertises full duplex ability in the Auto-Negotiation process regardless of the 
duplex setting of the CSMA unit. The CSMA configuration should match the result of the Auto- 
Negotiation. 


The selection of duplex operation (full or half) and flow control is done in two levels: MAC and 
PHY. The MAC duplex selection is done only through CSMA configuration mechanism (in other 
words, the Configure command from software). 


Flow Control 


The 82559 supports IEEE 802.3x frame based flow control frames only in both full duplex and half 
duplex switched environments. The 82559 flow control feature is not intended to be used in shared 
media environments. 


Flow control is optional in full duplex mode and can be selected through software configuration. 
There are three modes of flow control that can be selected: frame based transmit flow control, 
frame based receive flow control, and none. 


The PHY unit’s duplex and flow control enable can be selected using NWay* Auto-Negotiation 
algorithm or through the Management Data Interface. 


Address Filtering Modifications 


The 82559 can be configured to ignore one bit when checking for its Individual Address (IA) on 
incoming receive frames. The address bit, known as the Upper/Lower (U/L) bit, is the second least 
significant bit of the first byte of the IA. This bit may be used, in some cases, as a priority 
indication bit. When configured to do so, the 82559 passes any frame that matches all other 47 
address bits of its IA, regardless of the U/L bit value. 


This configuration only affects the 82559 specific IA and not multicast, multi-IA or broadcast 


address filtering. The 82559 does not attribute any priority to frames with this bit set, it simply 
passes them to memory regardless of this bit. 
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VLAN Support 


The 82559 supports the VLAN standard currently being defined by the IEEE 802.1 committee. All 
VLAN flows will be implemented by software. The 82559 supports the reception of long frames, 
specifically frames longer than 1518 bytes, including the CRC, if software sets the Long Receive 
OK bit in the Configuration command (described in the 10/100 Mbit Family Software Developer’s 
Manual). Otherwise, “long” frames are discarded. 


Media Independent Interface (MII) Management Interface 


The MII management interface allows the CPU to control the PHY unit via a control register in the 
82559. This allows the software driver to place the PHY in specific modes such as full duplex, 
loopback, power down, etc., without the need for specific hardware pins to select the desired mode. 
This structure allows the 82559 to query the PHY unit for status of the link. This register is the 
MDI Control Register and resides at offset 10H in the 82559 CSR. (The MDI registers are 
described in detail in Section 10.0, “PHY Unit Registers” on page 85.) The CPU writes commands 
to this register and the 82559 reads or writes the control/status parameters to the PHY unit through 
the MDI register. Although the82559 follows the MII format, the MI bus is not accessible on 
external pins. 
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100BASE-TX PHY Unit 


100BASE-TX Transmit Clock Generation 


A 25 MHz crystal or a 25 MHz oscillator is used to drive the PHY unit’s X1 and X2 pins. The PHY 
unit derives its internal transmit digital clocks from this crystal or oscillator input. The internal 
Transmit Clock signal is a derivative of the 25 MHz internal clock. The accuracy of the external 
crystal or oscillator must be + 0.0005% (50 PPM). 


100BASE-TX Transmit Blocks 


The transmit subsection of the PHY unit accepts nibble-wide data from the CSMA/CD unit. The 
transmit subsection passes data unconditionally to the 4B/5B encoder. 


The 4B/SB encoder accepts nibble-wide data (4 bits) from the CSMA unit and compiles it into 5- 
bit-wide parallel symbols. These symbols are scrambled and serialized into a 125 Mbps bit stream, 
converted by the analog transmit driver into a MLT-3 waveform format, and transmitted onto the 
Unshielded Twisted Pair (UTP) or Shielded Twisted Pair (STP) wire. 


100BASE-TX 4B/5B Encoder 


The 4B/5B encoder complies with the IEEE 802.3u 1OOBASE-TX standard. Four bits are encoded 
according to the transmit 4B/SB lookup table. The lookup table matches a 5-bit code to each 4-bit 
code. 


The table below illustrates the 4B/5B encoding scheme associated with the given symbol. 


Table 2. 4B/5B Encoder 















































Symbol 5B Symbol Code 4B Nibble Code 
0 11110 0000 
1 01001 0001 
2 10100 0010 
3 10101 0011 
4 01010 0100 
5 01011 0101 
6 01110 0110 
7 01111 0111 
8 10010 1000 
9 10011 1001 
A 10110 1010 
B 10111 1011 
Cc 11010 1100 
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Table 2. 4B/5B Encoder 







































































Symbol 5B Symbol Code 4B Nibble Code 
D 11011 1101 
E 11100 1110 
F 11101 1111 
| 411414 ay aa Idle Symbol 
J 41000 : te “i of Packet Symbol 
K 40001 ao of Packet Symbol 
T 01101 1st End of Packet Symbol 
ee 
Vv 00000 INVALID 
Vv 00001 INVALID 
Vv 00010 INVALID 
Vv 00011 INVALID 
H 00100 INVALID 
Vv 00101 INVALID 
Vv 00110 INVALID 
Vv 01000 INVALID 
Vv 01100 INVALID 
Vv 10000 PHY based Flow Control 
Vv 11001 INVALID 








100BASE-TX Scrambler and MLT-3 Encoder 


Data is scrambled in 1OOBASE-TX in order to reduce electromagnetic emissions during long 
transmissions of high-frequency data codes. The scrambler logic accepts 5 bits from the 4B/5B 
encoder block and presents the scrambled data to the MLT-3 encoder. The PHY unit implements 
the 11-bit stream cipher scrambler as adopted by the ANSI XT3T9.5 committee for UTP operation. 


The cipher equation used is: 


X[n] = X[n-11] + X[n-9] (mod 2) 


The encoder receives the scrambled Non-Return to Zero (NRZ) data stream from the Scrambler 
and encodes the stream into MLT-3 for presentation to the driver. MLT-3 is similar to NRZI coding, 
but three levels are output instead of two. There are three output levels: positive, negative and zero. 
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When an NRZ “0” arrives at the input of the encoder, the last output level is maintained (either 
positive, negative or zero). When an NRZ “1” arrives at the input of the encoder, the output steps to 
the next level. The order of steps is negative-zero-positive-zero which continues periodically. 


cee FLT LALOLPL PLA. 


NRZ 1 1 0 0 1 0 0 1 


NRZ1 1 1| 0 0] 1 0 0 1 


MLT-3 Spee ek 


Figure 13. NRZ to MLT-3 Encoding Diagram 


5.1.2.3 100BASE-TX Transmit Framing 


The PHY unit does not differentiate between the fields of the MAC frame containing preamble, 
Start of Frame Delimiter, data and Cyclic Redundancy Check (CRC). The PHY unit encodes the 
first byte of the preamble as the “JK” symbol, encodes all other pieces of data according to the 4B/ 
5B lookup table, and adds the “TR” code after the end of the packet. The PHY unit scrambles and 
serializes the data into a 125 Mbps stream, encodes it as MLT-3, and drives it onto the wire. 


5.1.2.4 Transmit Driver 


The transmit differential pair lines are implemented with a digital slope controlled current driver 
that meets the TP-PMD specifications. Current is sinked from the isolation transformer by the TDP 
and TDN pins. The conceptual transmit differential waveform for 100 Mbps is illustrated in the 
following figure. 


(Vapp-V ton) 
+1V 





>t 





Figure 14. Conceptual Transmit Differential Waveform 
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The magnetics module that is external to the PHY unit converts Ippp and [py to the 2.0 V,,,, as 
required by the TP-PMD specification. The same magnetics used for 1OOBASE-TX mode should 
also work in 1OBASE-T mode. The following is a list of current magnetics modules available from 
several vendors: 


Table 3. Magnetics Modules 




















Vendor Model/Type 100BASE-TX 10BASE-T 
Delta LF8200A Yes Yes 
Pulse Engineering PE-68515 Yes Yes 
Pulse Engineering H1012 Yes Yes 

















100BASE-TX Receive Blocks 


The receive subsection of the PHY unit accepts 1OOBASE-TX MLT-3 data on the receive 
differential pair. Due to the advanced digital signal processing design techniques employed, the 
PHY unit will accurately receive valid data from Category-5 (CAT5) UTP and Type 1 STP cable of 
length well in excess of 100 meters. 


Adaptive Equalizer 


The distorted MLT-3 signal at the end of the wire is restored by the equalizer. The equalizer 
performs adaptation based on the shape of the received signal, equalizing the signal to meet 
superior Data Dependent Jitter performance. 


Receive Clock and Data Recovery 


The clock recovery circuit uses advanced digital signal processing technology to compensate for 
various signal jitter causes. The circuit recovers the 125 MHz clock and data and presents the data 
to the MLT-3 decoder. 


MLT-3 Decoder, Descrambler, and Receive Digital Section 


The PHY unit first decodes the MLT-3 data; afterwards, the descrambler reproduces the 5B 
symbols originated in the transmitter. The descrambling is based on synchronization to the transmit 
11-bit Linear Feedback Shift Register (LFSR) during idle. The data is decoded at the 4B/5B 
decoder. Once the 4B symbols are obtained, the PHY unit outputs the receive data to the COMA 
unit. 


100BASE-TX Receive Framing 


The PHY unit does not differentiate between the fields of the MAC frame containing preamble, 
start of frame delimiter, data and CRC. During 100 Mbps reception, the PHY unit differentiates 
between the idle condition ("L" symbols on the wire) and the preamble or start of frame delimiter. 
When two non-consecutive bits are 0b within 10 bits (125 Mbps 5B data coding) the PHY unit 
immediately asserts carrier sense. When the “JK” symbols (11000, 10001’) are fully recognized, 
the PHY unit provides the received data to the CSMA unit. If the “JK” symbol is not recognized 
(“false carrier sense’’), the carrier sense is immediately de-asserted and a receive error is indicated. 
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100BASE-TX Receive Error Detection and Reporting 


In 1OOBASE-TX mode, the PHY unit can detect errors in receive data in a number of ways. Any of 
the following conditions is considered an error: 


¢ Link integrity fails in the middle of frame reception. 
¢ The Start of Stream Delimiter (SSD) “JK” symbol is not fully detected after idle. 
¢ An invalid symbol is detected at the 4B/5B decoder. 
¢ Idle is detected in the middle of a frame (before “TR” is detected). 
When any of the above error conditions occurs, the PHY unit immediately asserts its receive error 


indication to the CSMA unit. The receive error indication is held active as long as the receive error 
condition persists on the receive pair. 


100BASE-TX Collision Detection 


100BASE-TX collisions in half duplex mode only are detected similarly to L1OBASE-T collision 
detection, via simultaneous transmission and reception. 


100BASE-TX Link Integrity and Auto-Negotiation Solution 


The 82559 Auto-Negotiation function automatically configures the device to the technology, 
media, and speed to operate with its link partner. Auto-Negotiation is widely described in IEEE 
specification 802.3u, clause 28. The PHY unit supports L|OBASE-T half duplex, LOBASE-T full 
duplex, 1OOBASE-TX half duplex, and 1OOBASE-TX full duplex. 


The PHY unit has two Physical Media Attachment (PMA) technologies with its link integrity 
function, 1|OBASE-T and LOOBASE-TX. 


Link Integrity 
In 1OOBASE-TX, the link integrity function is determined by a stable signal status coming from the 


TP-PMD block. Signal status is asserted when the PMD detects breaking squelch energy and the 
right bit error rate according to the ANSI specification. 


Auto-Negotiation 


The PHY unit fully supports IEEE 802.3u, clause 28. The technology, |OBASE-T or 1OOBASE- 
TX, is determined by the Auto-Negotiation result. 


Speed and duplex auto-select are functions of Auto-Negotiation. However, these parameters may 
be manually configured via the MIT management interface (MDI registers). 


Auto 10/100 Mbps Speed Selection 


The MAC may either allow the PHY unit to automatically select its operating speed or force the 
PHY into 10 Mbps or 100 Mbps mode. The Management Data Interface (MDP) can control the 
PHY unit speed mode. 
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The PHY unit auto-select function determines the operation speed of the media based on the link 
integrity pulses it receives. If no Fast Link Pulses (FLPs) are detected and Normal Link Pulses 
(NLPs) are detected, the PHY unit defaults to 10 Mbps operation. If the PHY unit detects a speed 
change, it dynamically changes its transmit clock and receive clock frequencies to the appropriate 
value. This change takes a maximum of five milliseconds. 


10BASE-T Functionality 


10BASE-T Transmit Clock Generation 


The 20 MHz and 10 MHz clocks needed for 1OBASE-T are synthesized from the external 25 MHz 
crystal or oscillator. The PHY unit provides the transmit clock and receive clock to the internal 
MAC at 2.5 MHz. 


10BASE-T Transmit Blocks 


10BASE-T Manchester Encoder 


After the 2.5 MHz clocked data is serialized in a 10 Mbps serial stream, the 20 MHz clock 
performs the Manchester encoding. The Manchester code always has a mid-bit transition. If the 
value is 1b then the transition is from low to high. If the value is Ob then the transition is from high 
to low. The boundary transition occurs only when the data changes from bit to bit. For example, if 
the value is 10b, then the change is from high to low; if 01b, then the change is from low to high. 


10BASE-T Driver and Filter 


Since 1|OBASE-T and 100OBASE-TX have different filtration needs, both filters are implemented 
inside the chip. This allows the two technologies to share the same magnetics. The PHY unit 
supports both technologies through one pair of TD pins and by externally sharing the same 
magnetics. 


In 10 Mbps mode, the PHY unit begins transmitting the serial Manchester bit stream within 3 bit 
times (300 nanoseconds) after the MAC asserts TXEN. In 10 Mbps mode the line drivers use a pre- 
distortion algorithm to improve jitter tolerance. The line drivers reduce their drive level during the 
second half of “wide” (100ns) Manchester pulses and maintain a full drive level during all narrow 
(50ns) pulses and the first half of the wide pulses. This reduces line overcharging during wide 
pulses, a major source of jitter. 


10BASE-T Receive Blocks 


10BASE-T Manchester Decoder 


The PHY unit performs Manchester decoding and timing recovery when in 10 Mbps mode. The 
Manchester-encoded data stream is decoded from the RD pair to separate Receive Clock and 
Receive Data from the differential signal. This data is transferred to the CSMA unit at 2.5 MHz/ 
nibble. The high-performance circuitry of the PHY unit exceeds the IEEE 802.3 jitter 
requirements. 
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10BASE-T Twisted Pair Ethernet (TPE) Receive Buffer and Filter 


In 10 Mbps mode, data is expected to be received on the receive differential pair after passing 
through isolation transformers. The filter is implemented inside the PHY unit for supporting single 
magnetics that are shared with the 1OOBASE-TX side. The input differential voltage range for the 
Twisted Pair Ethernet (TPE) receiver is greater than 585 mV and less than 3.1 V. The TPE receive 
buffer distinguishes valid receive data, link test pulses, and the idle condition, according to the 
requirements of the 1|OBASE-T standard. 


The following line activity is determined to be inactive and is rejected: 
¢ Differential pulses of peak magnitude less than 300 mV 


¢ Continuous sinusoids with a differential amplitude less than 6.2 Vpp and frequency less than 2 
MHz 


e Sine waves of a single cycle duration starting with 0 or 180° phase that have a differential 
amplitude less than 6.2 Vpp and a frequency of at least 2 MHz and not more than 16 MHz. 
These single-cycle sine waves are discarded only if they are preceded by 4 bit times (400 
nanoseconds) of silence. 


All other activity is determined to be either data, link test pulses, Auto-Negotiation fast link pulses, 
or the idle condition. When activity is detected, the carrier sense signal is asserted to the MAC. 


10BASE-T Error Detection and Reporting 


In 10 Mbps mode, the PHY unit can detect errors in the receive data. The following condition is 
considered an error: 


The receive pair’s voltage level drops to the idle state during reception before the end-of-frame 
bit is detected (250 nanoseconds without mid-bit transitions). 


10BASE-T Collision Detection 


Collision detection in 10 Mbps mode is indicated by simultaneous transmission and reception. If 
the PHY unit detects this condition, it asserts a collision indication to the CSMA/CD unit. 


10BASE-T Link Integrity 


The link integrity in 10 Mbps works with link pulses. The PHY unit senses and differentiates those 
link pulses from fast link pulses and from 1OOBASE-TX idles. The 10 Mbps link pulses or normal 
link pulses are driven in the transmit differential pair line but are 100 ns wide and have levels from 
0 V to 5 V. The link beat pulse is also used to determine if the receive pair polarity is reversed. If it 
is, the polarity is corrected internally. 


10BASE-T Jabber Control Function 


The PHY unit contains a jabber control function that inhibits transmission after a specified time 
window when enabled. In 10 Mbps mode, the jabber timer is set to a value between 26.2 ms and 39 
ms. If the PHY unit detects continuous transmission that is greater than this time period, it prevents 
further transmissions from onto the wire until it detects that the MAC transmit enable signal has 
been inactive for at least 314 ms. 
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10BASE-T Full Duplex 


The PHY unit supports 10 Mbps full duplex by disabling the collision function, the squelch test, 
and the carrier sense transmit function. This allows the PHY unit to transmit and receive 
simultaneously, achieving up to 20 Mbps of network bandwidth. The configuration can be achieved 
through Auto-Negotiation. Full duplex should only be used in point-to-point connections (no 
shared media). 


Auto-Negotiation Functionality 


The PHY unit supports Auto-Negotiation. Auto-Negotiation is an automatic configuration scheme 
designed to manage interoperability in multifunctional LAN environments. It allows two stations 
with “N” different modes of communication to establish a common mode of operation. At power- 
up, Auto-Negotiation automatically establishes a link that takes advantage of an Auto-Negotiation 
capable device. An Auto-Negotiation capable device can detect and automatically configure its 
port to take maximum advantage of common modes of operation without user intervention or prior 
knowledge by either station. The possible common modes of operation are: 1OOBASE-TX, 
100BASE-TX Full Duplex, 1OBASE-T, and 1OBASE-T Full Duplex. 


Description 


Auto-Negotiation selects the fastest operating mode (in other words, the highest common 
denominator) available to hardware at both ends of the cable. A PHY’s capability is encoded by 
bursts of link pulses called Fast Link Pulses (FLPs). Connection is established by FLP exchange 
and handshake during link initialization time. Once the link is established by this handshake, the 
native link pulse scheme resumes (that is, LOBASE-T or 1OOBASE-TX link pulses). A reset or 
management renegotiate command (through the MDI interface) will restart the process. To enable 
Auto-Negotiation, bit 12 of the MDI Control Register must be set. If the PHY unit cannot perform 
Auto-Negotiation, it will set this bit to a 0 and determine the speed using Parallel Detection. 


The PHY unit supports four technologies: 1|OOBASE-Tx Full and Half Duplex and 1OBASE-T Full 
and Half Duplex. Since only one technology can be used at a time (after every re-negotiate 
command), a prioritization scheme must be used to ensure that the highest common denominator 
ability is chosen. Each bit in this table is set according to what the PHY is capable of supporting. In 
the case of the 82559’s PHY unit, bits 0, 1, 2, 3, and 5 (IOBASE-T, 1OBASE-T full duplex, 
100BASE-TX, 1OOBASE-TX full duplex and pause [frame based flow control], respectively) are 
set. 


To detect the correct technology, the two register fields, technology ability and technology priority, 
should be ANDed together to obtain the highest common denominator. This value should then be 
used to map into a priority resolution table used by the MAC driver to use the appropriate 
technology. 


Parallel Detect and Auto-Negotiation 


The PHY unit automatically determines the speed of the link either by using Parallel Detect or 
Auto-Negotiation. Upon a reset, a link status fail, or a Negotiate/Re-negotiate command, the PHY 
unit inserts a long delay during which no link pulses are transmitted. This period, known as 
Force_Fail, insures that the PHY unit‘s link partner has gone into a Link Fail state before Auto- 
Negotiation or Parallel Detection begins. Thus, both sides (PHY unit and PHY unit’s link partner) 
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will perform Auto-Negotiation or Parallel Detection with no data packets being transmitted. 
Connection is then established either by FLP exchange or Parallel Detection. The PHY unit will 
look for both FLPs and link integrity pulses. The following diagram illustrates this process. 
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Figure 15. Auto-Negotiation and Parallel Detect 


5.4 LED Description 


The PHY unit supports three LED pins to indicate link status, network activity and network speed. 
Each pin can source 10 mA. 


¢ Link: This LED is off until a valid link has been detected. After a valid link has been detected, 
the LED will remain on (active-low). 


¢ Activity: This LED blinks on and off when activity is detected on the wire. 


¢ Speed: This LED will be on if a 1OOBASE-TX link is detected and off if a 1OBASE-T link is 
detected. If the link fails while in Auto-Negotiation, this LED will keep the last valid link state. 
If 1OOBASE-TX link is forced this LED will be on, regardless of the link status. This LED will 
be of if the LOBASE-T link is forced, regardless of the link status. 


MDI register 27 in Section 10.3.12, “Register 27: PHY Unit Special Control Bit Definitions” on 
page 92 details the information for LED function mapping and support enhancements. 
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Figure 16 provides possible schematic diagrams for configurations using two and three LEDs. 
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Figure 16. Two and Three LED Schematic Diagram 
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6.0 82559 Modem Functionality 





The local port mimics the standard 8-bit interface of a modem to the host system and emulates a 
16550 Universal Asynchronous Receiver/Transceiver (UART) modem interface. The modem 
interface includes the following: 


° 8-bit data bus: FLD[7:0] 


* Control signals: AEN (FLCS#), MCNTSM# (FLA[12]), MINT (FLA[11]), MRING# 
(FLA[10]), MRST (FLA[9]), RD# (FLOE#), and WR# (FLWE#) 


¢ 4 address lines 


6.1 PCI Address Mapping to the Modem 


The modem can be accessed by the PCI bus through either I/O or memory mapping. 


6.2 Modem Read and Write Cycles 


Basic read/write cycles to the modem device are shown in the figure below. 





Modem AEN (CS#) | | 





Modem Addrsess X j X 





Modem Data In / Out | | X mi | 





Modem IOCHRDY 




















Modem WE# / RD# : : . ; 
Figure 17. Modem Read/Write Cycles 


6.3 Modem and Preboot eXtension Environment Coexistence 


The 82559 C-Step local bus interface supports either a Flash device or modem without external 
support. In addition, the 82559 can also support both devices concurrently on the bus. Support is 
provided through the use of the Security ASIC Chip Select (CFCS#) pin by using it in conjunction 
with the Flash Chip Select (FLCS#) signal to enable the target device. 


6.3.1 Programming Details 


For designs that use both Flash and modem devices, the 82559 C-step supports the coexistence of 
BootROM accesses (for Preboot eXtension Environment [PXE] code) and modem: 


1. Set the EEPROM’s MDM bit. 
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2. Clear the BD bit in the EEPROM. 


This enables both the modem and boot ROM. This allows the Boot Enable bit in the Expansion 
BAR to select which external device (modem or Flash) is active on the local bus through the use of 
the CFCS# pin. After initialization, the 82559 C-step enables the Flash on the local bus (in other 
words, the Boot Enable bit in the BAR equals 1b) and the modem is disabled. Following the 
execution of the boot code from the Flash device, the enable bit is cleared, and the modem is 
enabled. The clearing of the Boot Enable bit causes the CFCS# pin to be de-asserted, enabling the 
modem, Function | (Modem) Configuration space, to be available regardless of the state of the 
Boot Enable bit or CFCS#. 


6.3.2 Support Circuitry 


An example of support circuitry is shown in Figure 18. When CFCS# is low, the modem is enabled; 
CFCS# is high, the Flash device is enabled. 


FLCS# MODEM_CS# 


CFCS# FLASH _CS# 


(Modem_Mode#) 


Figure 18. Support Circuitry Example 
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82559 TCO Functionality 





fal 


Note: 


Datasheet 


The 82559 supports management communication to reduce Total Cost of Ownership (TCO). It has 
a System Management Bus (SMB) on which the 82559 is a slave device. The SMB is used as an 
interface between the 82559 and a TCO “entity”. The TCO entity may be a dedicated TCO 
controller, or it may be direct connection to a future integrated host controller. In the case of a 
direct connection to an integrated host controller, a larger EEPROM of 256 words would be 
required if the heartbeat command is used. The sections below describe the 82559’s functionality in 
the a system with a TCO controller and a system without a TCO controller. 


System Functionality with a TCO Controller 


When a TCO controller accesses the 82559 through the SMB, the bus operates as a half duplex 
channel. Therefore, once the TCO controller starts a transmit command or another execution 
command, it must complete it before responding to the SMB Alert (SMBALRT) cause and vise 
versa. The 82559 functionality available through the SMB is listed in the table below. 








Power State TCO Controller Functionality 
* Transmit 
* Set receive TCO packets 
DO Nominal * Receive TCO packets 


* Read 82559 status 
* Force TCO mode 





¢ DO functionality 


Dx (x > 0) . 
« Read PHY registers 





«Dx functionality 


* Configure commands (configuration, individual 
address, multicast, load microcode) 


*« Read/Write PHY registers 


Force TCO Mode 














DO Nominal Operation: 


In the DO power state, the 82559 can transfer TCO packets to the TCO controller. This feature is 
enabled by the set receive enable command from the TCO controller. The TCO packets are 
transferred to the 82559’s memory structure, Receive Frame Area (RFA); therefore, this feature 
requires software to be loaded and available receive resources. The 82559 suspends transmit and 
receive processes and sets the TCO request bit in the TCO State register. Afterwards, it transfers 
the TCO packet back to the TCO controller through the SMB and reclaims receive memory 
structures that are occupied by the TCO packet, eliminating the need for software intervention in 
the process. Finally, the 82559 increments the receive TCO statistic counter, clears the TCO 
request bit and resumes normal operation. The 82559 always increments the receive TCO counter 
following the reception of a TCO packet. 


Traffic between the 82559 and the TCO controller is limited by the SMB speed and the TCO 
controller latency. For example, for a system with a 100 KHz clock on the SMB, the bandwidth 
may be as low as 50 Kbps, which is a reception rate of approximately 100 packets per second for 
64-byte packets. 


Transmit Command during Nominal Operation 
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The 82559 completes the following process for the during nominal operation of the 
transmit command in TCO mode. 


1. The 82559 completes the current transmit DMA. 

2. The 82559 sets the TCO request bit in the TCO State register. 

3. The 82559 responds to the TCO controller’s transmit request. 

4. Upon completion of the TCO transmit DMA, the 82559 increments the transmit TCO 
statistic counter. 

5. Upon completion of the transmit operation, the 82559 increments the nominal 
transmit statistic counters and clears the TCO request bit in the TCO State register. 


6. The 82559 resumes its normal transmit flow. 
During the this time, the receive flow is not affected. 
Receive TCO Packets 


The 82559 supports receive flow towards the TCO controller. The 82559 can transfer 
either TCO packets or packets that pass MAC address filtering according to its 
configuration and mode of operation. If the 82559 is configured to transfer only TCO 
packets, it supports Ethernet Type II packets with optional VLAN tagging. 


Read 82559 Status (Power Management and Link State) 


The TCO controller is capable of reading the 82559’s power state and link status. 
Following a status change the 82559 issues an SMB alert and the TCO entity reads the 
new power state. 


Set Force TCO Mode 


The TCO controller can set the 82559 into the Force TCO mode. The 82559 is set back to 
the nominal operation following a PCI RST# or ALTRST#. After the transition from 
normal operation to TCO mode, the 82559 aborts transmit and receive operations and 
clears its memory structures. The TCO may configure the 82559 before it starts transmit 
and receive operations if required. 


Caution: The Force TCO is a destructive command. It causes the 82559 to lose its 
memory structures. Also, in Force TCO mode, the 82559 ignores PCI cycles. Therefore, it 
is highly recommended to use this command by the TCO controller at system emergency 
only. 


Dx (x>0): 
When the 82559 is in a low power state (D1, D2, or D3), it may receive TCO packets directly 
to the TCO controller. TCO packet reception is enabled by setting the receive enable command 
from the TCO controller. Although TCO packets can match other wake-up filters, once it is 
identified as a TCO packet, no further matching is performed. When TCO reception is 
disabled, a TCO packet may cause a power management event if configured to so by the load 
wake-up packet command. 


Force TCO Mode: 


When the 82559 is in the force TCO mode, it may receive packets directly to the TCO controller. 
TCO packet reception and filtering is controlled by the set receive enable command from the TCO 
controller. After receiving a TCO packet, the 82559 increments its nominal receive statistic 
counters as well as the receive TCO counter. 
Configuration Commands 
While the 82559 is in the force TCO mode it supports the Configure CSMA, Individual 
Address Setup, Multicast Setup, Load Microcode commands and allows read/write access 
to the PHY registers. 
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Figure 19. 
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System Functionality without a TCO Controller 


This section describes the 82559 functionality when it is connected on the SMB directly to an 
integrated host controller. 


Receive Functionality - In the power-up state, the 82559 transfers TCO packets to the host as any 
other packet. These packets include a new status indication bit in the 82559’s Receive Frame 
Descriptor (RFD) status and have a specific port number indicating TCO packet recognition. In the 
power-down state, the TCO packets are treated as a wake-up packets. The 82559 asserts the PME# 
signal and delivers the first 120 bytes of the packet to the host. 


Transmit Functionality - The 82559 supports the Heartbeat (HB) transmission command from the 
SMB interface. The send HB packet command includes a system health status issued by the 
integrated system controller. The 82559 computes a matched checksum and CRC and will 
transmit the HB packet from its serial EEPROM. The HB packet size and structure are not limited 
as long as it fits within the EEPROM size. In this case, the EEPROM size is 256 words to enable 
the storage of the HB packet (the first 64 words are used for driver specific data). 


On the SMB, the send heartbeat packet command is not normally used in the DO power state. The 
one exception in which it is used in the DO state is when the system is hung. In normal operating 
mode, the heartbeat packets are transmitted through the 82559’s software similar to other packets. 


TCO Interface 


Support for a TCO controller is through a dedicated SMB interface. The 82559 acts as a slave on 
the SMB and supports data (SMBD), clock (SMBCLK), and alert (SMBALRT#) signals. The 
82559 meets the 100 KHz SMB requirements according to the specification. It is also functional 
with an increased clock frequency of up to 1 MHz and still meets all required SMB timings. A 
basic SMB wave form diagram is shown in Figure 19. 








































































































SMBCLK | 
SMBD start stop 
MSB | ADDR |R/W# CMD BC DATA 
ACK ACK ACK ACK 
SMB Session 


SMB Alert Signal (SMBALRT#) 


The 82559 operates in slave mode on the SMB during both read and write cycles. When the 82559 
transmits data on the SMB (receive packet), it issues the SMBALRT# signal. In response to the 
SMBALRT# activation, the host processes the interrupt. It accesses all SMB devices 
simultaneously by an Alert Response Address (ARA) cycle. The device(s) that issued the 
SMBALRT# signal acknowledges the cycle. If more than one device issued the SMBALRT#, the 
highest priority (lowest address) device will win communication. Only the winning device can de- 
asserts its SMBALRT# signal. 


As a Slave device, the 82559 signals the external TCO Controller using SMBALRT#. The 
SMBALRT# signal is activated for the following events: 
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¢ TCO packet received 
¢ Low power state change 
¢ PHY read 
7.3.2 Alert Response Address (ARA) Cycle 


If a slave device needs to initiate a session, it should assert the SMBALRT signal as follow: 
























































SMBALRT# | The SMBALRT# will rise only if an address match exists. 

start stop 
SMBCLK 
SMBD MSE | 1| ack [mse| [1] ACK 


























Figure 20. Slave Request for Data Transfer 


If the 82559 is not ready, it indicates this in one of two ways: 


1. If the 82559’s PHY unit is in a low power state, the 82559 will not produce the acknowledge 
bit after its address appears on the bus. This forces the TCO controller to stop the session and 
restart it. 

2. If the 82559’s PHY unit is in nominal mode, the 82559 will pull-down the SMBCLK until it is 
ready. If the 82559 forces the SMBCLK for more then 25 ms, the TCO controller should stop 
the transmission and restart it. 
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PCI and CardBus Configuration Registers 





8.1 


Figure 21. 


8.1.1 
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The 82559 acts as both a master and a slave on the PCI bus. As a master, the 82559 interacts with 
the system main memory to access data for transmission or deposit received data. As a slave, some 
82559 control structures are accessed by the host CPU to read or write information to the on-chip 
registers. The CPU also provides the 82559 with the necessary commands and pointers that allow it 
to process receive and transmit data. 


Function 0: LAN (Ethernet) PCI Configuration Space 


The 82559 PCI configuration space is configured as 16 Dwords of Type 0 Configuration Space 
Header, as defined in the PCI Specification, Revision 2.1. A small section is also configured 
according to its device specific configuration space. The configuration space header is depicted 
below in Figure 21. 



















































































Device ID Vendor ID 00H 

Status Command 04H 

Class Code Revision ID 08H 

BIST Header Type Latency Timer Cache Line Size OCH 
CSR Memory Mapped Base Address Register 10H 

CSR I/O Mapped Base Address Register 14H 

Flash Memory Mapped Base Address Register 18H 

Reserved Base Address Register 1CH 

Reserved Base Address Register 20H 

Reserved Base Address Register 24H 

Reserved (PCIl)/CIS Pointer (CardBus) 28H 

Subsystem ID Subsystem Vendor ID 2CH 
Expansion ROM Base Address Register 30H 

Reserved Cap_Ptr 34H 

Reserved 38H 

Max_Lat Min_Gnt Interrupt Pin Interrupt Line 3CH 
Power Management Capabilities Next Item Ptr Capability ID DCH 
Reserved Data Power Management CSR EOH 











PCI Configuration Registers 


PCI Vendor ID and Device ID Registers 


The Vendor ID and Device ID of the 82559 are both read only word entities. Their values are: 


Vendor ID: 8086H 
Device ID: 1229H 
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PCI Command Register 


The 82559 Command register at word address 04H in the PCI configuration space provides control 
over the 82559’s ability to generate and respond to PCI cycles. If a OHis written to this register, the 
82559 is logically disconnected from the PCI bus for all accesses except configuration accesses. 
The format of this register is shown in the figure below. 


Figure 22. PCl Command Register 





SERR# Enable 


Parity Error Response 
Memory Write and Invalidate Enable 
Bus Master Enable 


Memory Space 
IO space 


rere TT eT 


109 8 7 6 54 3 2 1 «0 























Note that bits three, five, seven, and nine are set to Ob. The table below describes the bits of the PCI 
Command register. 


Table 4. PCI Command Register Bits 





Bits 


Name 


Description 





15:10 


Reserved 


These bits are reserved and should be set to 000000b. 





SERR# Enable 


This bit controls a device's ability to enable the SERR# driver. A value of Ob 
disables the SERR# driver. A value of 1b enables the SERR# driver. This 
bit must be set to report address parity errors. In the 82559, this bit is 
configurable and has a default value of Ob. 





Parity Error Control 


This bit controls a device’s response to parity errors. A value of Ob causes 
the device to ignore any parity errors that it detects and continue normal 
operation. A value of 1b causes the device to take normal action when a 
parity error is detected. This bit must be set to Ob after RST# is asserted. In 
the 82559, this bit is configurable and has a default value of Ob. 





Memory Write and 
Invalidate Enable 


This bit controls a device's ability to use the Memory Write and Invalidate 
command. A value of Ob disables the device from using the Memory Write 
and Invalidate Enable command. A value of 1b enables the device to use 
the Memory Write and Invalidate command. In the 82559, this bit is 
configurable and has a default value of Ob. 





Bus Master 


This bit controls a device’s ability to act as a master on the PCI bus. A value 
of 0b disables the device from generating PCI accesses. A value of 1b 
allows the device to behave as a bus master. In the 82559, this bit is 
configurable and has a default value of Ob. 





Memory Space 


This bit controls a device’s response to the memory space accesses. A 
value of Ob disables the device response. A value of 1b allows the device to 
respond to memory space accesses. In the 82559, this bit is configurable 
and its default value of Ob. 











I/O Space 





This bit controls a device’s response to the I/O space accesses. A value of 
Ob disables the device response. A value of 1b allows the device to 
respond to I/O space accesses. In the 82559, this bit is configurable and 
the default value of Ob. 
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The 82559 Status register is used to record status information for PCI bus related events. The 
format of this register is shown in the figure below. 





Detected Parity Erro 


Signaled System Error 
Received Master Abort 
Received Target Abort 
Signaled Target Abort 


31 


29 28 27 26 25 24 23 22 21 20 19 


“TT Toto tT do loT [ esened | 













Devsel Timing 


Parity Error Detected 
Fast Back To Back (target) 


Capabilities List 


Figure 23. PCI Status Register 




















Note that bits 21, 22, 26, and 27 are set to Ob and bits 20, 23, and 25 are set to 1b. The PCI Status 
register bits are described in the table below. 


Table 5. PCI Status Register Bits 
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Bits 


Name 


Description 





31 


Detected Parity Error 


This bit indicates whether a parity error is detected. This bit must be 
asserted by the device when it detects a parity error, even if parity error 
handling is disabled (as controlled by the Parity Error Response bit in the 
PCI Command register, bit 6). In the 82559, the initial value of the Detected 
Parity Error bit is Ob. This bit is set until cleared by writing a 1b. 





30 


Signaled System Error 


This bit indicates when the device has asserted SERR#. In the 82559, the 
initial value of the Signaled System Error bit is Ob. This bit is set until 
cleared by writing a 1b. 





29 


Received Master 
Abort 


This bit indicates whether or not a master abort has occurred. This bit must 
be set by the master device when its transaction is terminated with a 
master abort. In the 82559, the initial value of the Received Master Abort 
bit is Ob. This bit is set until cleared by writing a 1b. 





28 


Received Target Abort 


This bit indicates that the master has received the target abort. This bit 
must be set by the master device when its transaction is terminated by a 
target abort. In the 82559, the initial value of the Received Target Abort bit 
is Ob. This bit is set until cleared by writing a 1b. 





27 


Signaled Target Abort 


This bit indicates whether a transaction was terminated by a target abort. 
This bit must be set by the target device when it terminates a transaction 
with target abort. In the 82559, this bit is always set to Ob. 





26:25 








DEVSEL# Timing 





These two bits indicate the timing of DEVSEL#: 
00b - Fast 
01b - Medium 
10b - Slow 
11b - Reserved 
In the 82559, these bits are always set to 01b, medium. 
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Table 5. PCI Status Register Bits 


8.1.4 


8.1.5 


8.1.6 
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Bits Name Description 





This bit indicates whether a parity error has been detected. This bit is set to 
1b when the following three conditions are met: 


1. The bus agent asserted PERR# itself or observed PERR# asserted. 

2. The agent setting the bit acted as the bus master for the operation in 
which the error occurred. 

3. The Parity Error Response bit in the command register (bit 6) is set. 

In the 82559, the initial value of the Parity Error Detected bit is Ob. This bit 

is set until cleared by writing a 1b. 


24 Parity Error Detected 





This bit indicates a device's ability to accept fast back-to-back transactions 
when the transactions are not to the same agent. A value of 0b disables 
fast back-to-back ability. A value of 1b enables fast back-to-back ability. In 
the 82559, this bit is read only and is set to 1b. 


23 Fast Back-to-Back 





This bit indicates whether the 82559 implements a list of new capabilities 
such as PCI Power Management. A value of 0b means that this function 
does not implement the Capabilities List. If this bit is set to 1b, the Cap_Ptr 
register provides an offset into the 82559 PCI Configuration space pointing 
to the location of the first item in the Capabilities List. This bit is set only if 
the power management bit in the EEPROM is set. 


20 Capabilities List 

















19:16 Reserved These bits are reserved and should be set to 0000b. 





PCI Revision ID Register 


The Revision ID is an 8-bit read only register with a default value of 08H for the 82559. The three 
least significant bits of the Revision ID can be overridden by the ID and Revision ID fields in the 
EEPROM (Section 4.7, “Serial EEPROM Interface” on page 33). 


PCI Class Code Register 


The Class Code register is read only and is used to identify the generic function of the device and, 
in some cases, specific register level programming interface. The register is broken into three byte 
size fields. The upper byte is a base class code and specifies the 82559 as a network controller, 2H. 
The middle byte is a subclass code and specifies the 82559 as an Ethernet controller, 0H. The lower 
byte identifies a specific register level programming interface and the 82559 always returns a OH in 
this field. 


PCI Cache Line Size Register 


In order for the 82559 to support the Memory Write and Invalidate (MWI) command, the 82559 
must also support the Cache Line Size (CLS) register in PCI Configuration space. The register 
supports only cache line sizes of 8 and 16 Dwords. Any value other than 8 or 16 that is written to 
the register is ignored and the 82559 does not use the MWI command. If a value other than 8 or 16 
is written into the CLS register, the 82559 returns all zeroes when the CLS register is read. The 
figure below illustrates the format of this register. 


7 6 5 4 3 2 1 0 





0 0 0 RW RW 0 0 0 
































Figure 24. Cache Line Size Register 
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Bit 3 is set to 1b only if the value 00001000b (8H) is written to this register, and bit 4 is set to 1b 
only if the value of 00010000b (16H) is written to this register. All other bits are read only and will 
return a value of Ob on read. 


This register is expected to be written by the BIOS and the 82559 driver should not write to it. 


PCI Latency Timer 


The Latency Timer register is a byte wide register. When the 82559 is acting as a bus master, this 
register defines the amount of time, in PCI clock cycles, that it may own the bus. 


PCI Header Type 


The Header Type register is a byte read only register. It is equal to OOH for a single function 
Ethernet card and 80H for a combination Ethernet and modem card. The value of the header type is 
set by the EEPROM (Section 4.7, “Serial EEPROM Interface” on page 33). In a dual function card, 
the OS will read the next configuration registers bank at offset 100H. 


PCI Base Address Registers 


One of the most important functions for enabling superior configurability and ease of use is the 
ability to relocate PCI devices in address spaces. The 82559 contains three types of Base Address 
Registers (BARs). Two are used for memory mapped resources, and one is used for I/O mapping. 
Each register is 32 bits wide. The least significant bit in the BAR determines whether it represents 
a memory or I/O space. The figures below show the layout of a BAR for both memory and I/O 
mapping. After determining this information, power-up software can map the memory and I/O 
controllers into available locations and proceed with system boot. In order to do this mapping in a 
device independent manner, the base registers for this mapping are placed in the predefined header 
portion of configuration space. Device drivers can then access this configuration space to determine 
the mapping of a particular device. 


























31 43210 
Base Address 0 
4 A 
Prefetchable 
The prefetchable bit is set to ‘0’ in 82559 devices 
Type 


00 - locate anywhere in 32-bit address space 
01 - locate below 1 Mbyte 
10 - locate anywhere in 64-bit address space 
11 - reserved 

Memory space indicator 











Figure 25. Base Address Register for Memory Mapping 


Datasheet 


59 


a 
82559 — Networking Silicon ] ntl a 


31 210 

















Base Address 


0/1 
Reserved i i 


I/O space indicator 











Figure 26. Base Address Register for I/O Mapping 


Note: 


8.1.9.1 


8.1.9.2 


8.1.9.3 


8.1.9.4 
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Bit 0 in all base registers is read only and used to determine whether the register maps into memory 
or I/O space. Base registers that map to memory space must return a Ob in bit 0. Base registers that 
map to I/O space must return 1b in bit 0. 


Base registers that map into I/O space are always 32 bits wide with bit 0 hard-wired to a 1b, bit | is 
reserved and must return Ob on reads, and the other bits are used to map the device into I/O space. 


The number of upper bits that a device actually implements depends on how much of the address 
space the device will respond to. For example, a device that wants a 1 Mbyte memory address 
space would set the most significant 12 bits of the base address register to be configurable, setting 
the other bits to Ob. 


The 82559 contains BARs for the Control/Status Register (CSR), Flash, and Expansion ROM. 


CSR Memory Mapped Base Address Register 


The 82559 requires one BAR for memory mapping. Software determines which BAR, memory or 
I/O, is used to access the 82559 CSR registers. 


The memory space for the 82559 CSR Memory Mapped BAR is 4 Kbytes. The space is marked as 
not prefetchable and is mapped anywhere in the 32-bit memory address space. 


CSR I/O Mapped Base Address Register 


The 82559 requires one BAR for I/O mapping. Software determines which BAR, memory or I/O, is 
used to access the 82559 CSR registers. The I/O space for the 82559 CSR I/O BAR is 64 bytes. 


Flash Memory Mapped Base Address Register 


The Flash Memory BAR is a Dword register. The 82559 physically supports a 128 Kbyte Flash 
device. In a CardBus system, the upper section of the memory mapped window (above the physical 
Flash device) is used for CIS information. The 82559 claims a window of 128 Kbytes in CardBus 
mode and always claims a Flash memory window, regardless of whether or not a Flash device is 
connected. 


Expansion ROM Base Address Register 


The Expansion ROM has a memory space of | Mbyte and its BAR is a Dword register that supports 
a 128 Kbyte memory via the 82559 local bus. The Expansion ROM BAR can be disabled by setting 
the Boot Disable bit of the EEPROM (word AH, bit 11). If the Boot Disable bit is set, the 82559 
returns a Ob for all bits in this address register, avoiding request of memory allocation for this 
space. In LAN/modem combination designs using Flash, this bit controls the state of the CFCS# 
signal (pin L7) and is cleared after the initial access of the expansion ROM area. Therefore, in a 
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LAN/modem combination design, the CFCS# signal will be de-asserted (high) when the Boot 
Disable bit is not set in the EEPROM and the ROM enable bit is set in the Expansion ROM Base 
Address Register. After the initial access to the Expansion ROM BAR, the Boot Disable bit is 
cleared and CFCS# is asserted (low) enabling the modem to use the local bus. 


Base Address Registry Summary 


The preceding description of the Base Address Registers’ functions are summarized in the 
following table: 


Base Address Register Functionalities 






































pea PCI Function PCI Window CardBus Function CardBus Window 
BARO Memory CSR 4 Kbyte Memory CSR 4 Kbyte 
BAR1 VO CSR 4 Kbyte (0 CSR 4 Kbyte 
BAR2 Flash 128 Kbyte CIS at offset + 64 Kbyte 128 Kbyte 
Expansion N/A 
BootROM 1 Mbyt 1 Mbyt 
BAR? ms (Disabled by EEPROM) ue 





a. The Expansion BAR can be disabled by setting the Boot Disable bit in the EEPROM. 


CardBus Card Information Structure (CIS) Pointer 


The Card Information Structure (CIS) pointer is a Dword hard coded read only register. It is 
meaningful only in a CardBus system (in a PCI system it is zero). The CIS pointer defines where 
the CIS structure is mapped in the Flash address space. 











Bits R/W Default Description 
31:4 R 1000H Ethernet CIS Pointer (above the physical Flash window) 
3:0 R 3H CIS in the Flash window 























PCI Subsystem Vendor ID and Subsystem ID Registers 


The Subsystem Vendor ID field identifies the vendor of an 82559-based solution. The Subsystem 
Vendor ID values are based upon the vendor’s PCI Vendor ID and is controlled by the PCI Special 
Interest Group (SIG). 


The Subsystem ID field identifies the 82559-based specific solution implemented by the vendor 
indicated in the Subsystem Vendor ID field. 


The 82559 provides support for configurable Subsystem Vendor ID and Subsystem ID fields. After 
hardware reset is de-asserted, the 82559 automatically reads addresses AH through CH of the 
EEPROM. The first of these 16-bit values is used for controlling various 82559 functions. The 
second is the Subsystem ID value, and the third is the Subsystem Vendor ID value. Again, the 
default values for the Subsystem ID and Subsystem Vendor ID are OH and OH, respectively. 
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The 82559 checks bit numbers 15, 14, and 13 in the EEPROM, word AH and functions according 
to Table 7 below. 


Table 7. 82559 ID Fields Programming 


8.1.13 


8.1.14 


8.1.15 


8.1.16 
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ane 4 

Signature ID AItID | Device | Vendor schiatinidliead Subsystem | Subsystem 

(Bits 15:14) | (Bit 13) | (Bit 7) ID ID B-step Cas ID Vendor ID 

11b°, 10b, X X 1229H | 8086H | 08H 09H 0000H 0000H 

00b 

O1b 1b X 1229H | 8086H | Word AH, | Word AH, | Word BH Word CH 
bits 10:8 | bits 10:8 

01b Ob 1b 1229H | 8086H | 08H 09H Word BH Word CH 

01b Ob Ob 1029H | 8086H | 08H 09H Word BH Word CH 



































a. The Revision ID is subject to change according to the silicon stepping. 
b. If bit 15 equals 1b, the EEPROM is invalid and the default values are used. 


The above table implies that if the 82559 detects the presence of an EEPROM (as indicated by a 
value of 01b in bits 15 and 14), then bit number 13 determines whether the values read from the 
EEPROM, words BH and CH, will be loaded into the Subsystem ID (word BH) and Subsystem 
Vendor ID (word CH) fields. If bits 15 and 14 equal 01b and bit 13 equals 1b, the three least 
significant bits of the Revision ID field are programmed by bits 8-10 of the first EEPROM word, 
word AH. 


Between the de-assertion of reset and the completion of the automatic EEPROM read, the 82559 
does not respond to any PCI configuration cycles. If the 82558 happens to be accessed during this 


time, it will Retry the access. More information on Retry is provided in Section 4.2.1.1.3, “Retry 
Premature Accesses” on page 20. 


Capability Pointer 


The Capability Pointer is a hard coded byte register with a value of DCH. It provides an offset 
within the Configuration Space for the location of the Power Management registers. 


Interrupt Line Register 


The Interrupt Line register identifies which system interrupt request line on the interrupt controller 
the device’s PCI interrupt request pin (as defined in the Interrupt Pin register) is routed to. 


Interrupt Pin Register 


The Interrupt Pin register is read only and defines which of the four PCI interrupt request pins, 
INTA# through INTD#, a PCI device is connected to. The 82559 is connected the INTA# pin. 


Minimum Grant Register 


The Minimum Grant (Min_Gnt) register is an optional read only register for bus masters and is not 
applicable to non-master devices. It defines the amount of time the bus master wants to retain PCI 
bus ownership when it initiates a transaction. The default value of this register for the 82559 is 
O8H. 
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Maximum Latency Register 


The Maximum Latency (Max_Lat) register is an optional read only register for bus masters and is 
not applicable to non-master devices. This register defines how often a device needs to access the 
PCI bus. The default value of this register for the 82559 is 18H. 


Capability ID Register 


The Capability ID is a byte register. It signifies whether the current item in the linked list is the 
register defined for PCI power management. PCI power management has been assigned the value 
of 02H. The 82559 is fully compliant with the PCI Power Management Specification, Revision 2.2. 


Next Item Pointer 


The Next Item Pointer is a byte register. It describes the location of the next item in the 82559’s 
capability list. Since power management is the last item in the list, this register is set to Ob. 


Power Management Capabilities Register 


The Power Management Capabilities register is a word read only register. It provides information 
on the capabilities of the 82559 related to power management. The 82559 reports a value of FE21H 
if it is connected to an auxiliary power source and 7E21H otherwise. It indicates that the 82559 
supports wake-up in the D3 state if power is supplied, either V., or Vayx. 


Power Management Capability Register 

















Bits Default Read/Write Description 

31:27 | 00011b | ReadOnly | PME Support. This five bit field indicates the power states in which 
(no Vaux) the 82559 may assert PME#. The 82559 supports wake-up in all 
11111b power states if it is fed by an auxiliary power supply (Vayx) and DO, 
(Vaux) D1, D2, and D3ho if it is fed by PCI power. 

26 1b Read Only D2 Support. If this bit is set, the 82559 supports the D2 power state. 

25 1b Read Only D1 Support. If this bit is set, the 82559 supports the D1 power state. 

24:22 | 000b Read Only Auxiliary Current. This field reports whether the 82559 implements 


the Data registers. The auxiliary power consumption is the same as 
the current consumption reported in the D3 state in the Data register. 





21 1b Read Only Device Specific Initialization (DSI). The DSI bit indicates whether 
special initialization of this function is required (beyond the standard 
PCI configuration header) before the generic class device driver is 
able to use it. DSI is required for the 82559 after D3-to-D0O reset. 











20 Ob (PCI) | ReadOnly | Reserved (PCI)/Auxiliary Power Source (CardBus). When this bit 
1b is set to ‘1’, it indicates that the 82559 requires auxiliary power 
(CardBus) supplied by the system for wake-up from the D3,oig state. 

19 Ob Read Only PME Clock. The 82559 does not require a clock to generate a power 

management event. 

18:16 | 010b Read Only Version. A value of 010b indicates that the 82559 complies with of 

















the PCI Power Management Specification, Revision 2.2. 
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8.1.21 Power Management Control/Status Register (PMCSR) 


The Power Management Control/Status is a word register. It is used to determine and change the 
current power state of the 82559 and control the power management interrupts in a standard 
manner. 


Table 9. Power Management Control and Status Register 





Bits Default Read/Write Description 





15 Ob Read/Clear | PME Status. This bit is set upon a wake-up event. It is independent of 
the state of the PME Enable bit. If 1b is written to this bit, the bit will be 
cleared. It also de-asserts the PME# signal and clears the PME status 
bit in the Power Management Driver Register. When the PME# signal 

is enabled, the PME# signal reflects the state of the PME status bit. 


In a CardBus system, writing a 1b to this bit clears the GWAKE bit in 
the Function Event register. The Function Event register is described in 
Section 9.1.14.1, “LAN Function Event Register” on page 77. 





14:13 | 00b Read Only Data Scale. This field indicates the data register scaling factor. It 
equals 10b for registers zero through eight and 00b for registers nine 
through fifteen. 




















12:9 0000b Read Only Data Select. This field is used to select which data is reported through 
the Data register and Data Scale field. 

8 Ob Read Clear | PME Enable. This bit enables the 82559 to assert PME#. 

7:5 000b Read Only Reserved. These bits are reserved and should be set to O00b. 

4 Ob Read Only Dynamic Data. The 82559 does not support the ability to monitor the 
power consumption dynamically. 

3:2 00b Read Only Reserved. These bits are reserved and should be set to 00b. 

1:0 00b Read/Write | Power State. This 2-bit field is used to determine the current power 


state of the 82559 and to set the 82559 into a new power state. The 
definition of the field values is as follows. 


00 - DO 
01 - D1 
10- D2 
11-D3 




















8.1.22 Data Register 


The data register is an 8-bit read only register that provides a mechanism for the 82559 to report 
state dependent maximum power consumption and heat dissipation. The value reported in this 
register depends on the value written to the Data Select field in the PMCSR register. The power 
measurements defined in this register have a dynamic range of 0 to 2.55 W with 0.01 W resolution 
according to the Data Scale. The value in this register is hard coded in the silicon. The structure of 
the data register differs between the 82559 B-step and C-step. The are presented below in Table 10 
and Table 11, respectively. 


Table 10. 82559 B-step Ethernet Data Register 














Data Select | Data Scale Data Reported 
0 2 DO Power Consumption = 58 (580 mW) 
1 2 D1 Power Consumption = 40 (400 mW) 
2 2 D2 Power Consumption = 40 (400 mW) 
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Table 10. 82559 B-step Ethernet Data Register 



































Data Select | Data Scale Data Reported 

3 2 D3 Power Consumption = 40 (400 mW) 

4 2 DO Power Dissipated = 58 (580 mW) 

5 2 D1 Power Dissipated = 40 (400 mW) 

6 2 D2 Power Dissipated = 40 (400 mW) 

7 2 D3 Power Dissipated = 40 (400 mW) 

8 2 Common Function Power Dissipated = 00 

9-15 0 Reserved (00H) 








Table 11. 82559 C-step Ethernet Data Register 





Data Select 


Data Scale 


Data Reported 





DO Power Consumption = 60 (600 mW 








( 
D1 Power Consumption = 42 (420 mW 
D2 Power Consumption = 42 (420 mW 





) 
) 
) 
) 


D3 Power Consumption = 42 (420 mW 





DO Power Dissipated = 60 (600 mW 








( ) 
D1 Power Dissipated = 42 (420 mW) 
D2 Power Dissipated = 42 (420 mW) 





D3 Power Dissipated = 42 (420 mW) 





CO] NN]! Om] oo} BR] WwW] P 


Common Function Power Dissipated = 00 








9-15 





O;}M] M] NM! MY] MH] MH] MH] MH] PY 





Reserved (00H) 
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8.2 


Function 1: Modem PCI Configuration Space 


In PCI systems and CardBus systems, the 82559 supports a dual function device: LAN/modem. 
The LAN is defined as function zero, and the modem is defined as function one. The modem 
function is active depending on the EEPROM setup. 










































































Modem Configuration ID 00H 

Modem Status Modem Command 04H 

Modem Revision ID 08H 

BIST Modem Header Type Latency Timer Cache Line Size OCH 
Modem I/O Mapped Base Address Register 10H 

Modem Memory Mapped Base Address Register 14H 

Reserved Base Address Register 18H 

Reserved Base Address Register 1CH 

Reserved Base Address Register 20H 

Reserved Base Address Register 24H 

Reserved (PCl)/Modem CIS Pointer (CardBus) 28H 

Modem Subsystem ID Modem Subsystem Vendor ID 2CH 
Expansion ROM Base Address Register 30H 

Reserved Cap_Ptr 34H 

Reserved 38H 

Max_Lat Min_Gnt Modem Interrupt 3CH 
Modem Power Management Capabilities Next Item Ptr Capability ID DCH 
Reserved Modem Data Modem Power Management CSR EOH 




















Figure 27. Modem PCI Configuration Registers 
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The modem configuration registers define the resources required by the modem function. It is 
meaningful in a multifunction card design only. Some of the modem configuration registers are a 
reflection of their matched Ethernet registers. The registers’ values are pre-defined by hardware, 
initialized by the EEPROM, or configurable through software. The shaded fields are described in 
detail in the following subsections. 


Modem Configuration ID Register 


The Modem Configuration ID field is a Dword register composed of the Device ID and Vendor ID. 
It is a read only register and its value is loaded from the EEPROM. 
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8.2.2 Modem Command Register 


The Modem Command field is a 16 bit word register and provides basic control over the modem’s 
ability to respond to PCI/CardBus accesses. The Command register’s structure is shown in the table 


below. 


Table 12. Power Management Control and Status Register 
























































Bits Default Read/Write Description 
15:10 | 000000b | Read Only Reserved. These bits are reserved and should be set to 000000b. 
9 Ob Read Only Fast Back-to-Back. 

8 Ob Read/Write | System Error Enable. 
7 Ob Read Only Wait Cycle Enable. 
6 Ob Read/Write | Parity Error Enable. 
5 Ob Read Only VGA (define). 
4 Ob Read Only Memory Write and Invalidate. 
3 Ob Read Only Special Cycle. 
2 Ob Read Only Master Enable. 
1 Ob Read/Write | Memory Access Enable. 
0 Ob Read/Write | I/O Access Enable. 
8.2.3 Modem Status Register 


The Modem Status field is a 16 bit word register. It provides basic track of CardBus related events. 


All bits are cleared by PCI RST#. 


Table 13. Modem Status Register 









































Bits Default Read/Write Description 
15 0 Read/Write | Parity Error. 
14 0 Read/Write | System Error Enable. 
13:11 000 Read Only Signaled/Received Target Abort. 
10:9 01 Read Only Device Select Timing. 
8 0 Read Only Data Parity Detect. 
7 0 Read Only Fast Back-to-Back Capable. 
6:5 00 Read Only Reserved. These bits are reserved and should be set to OOb. 
4 1 Read Only New Capability. 
3:0 0000 Read Only Reserved. These bits are reserved and should be set to 0000b. 
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8.2.4 


Table 14. 


8.2.5 


8.2.6 


8.2.7 


8.2.8 


8.2.9 
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Modem Revision ID Register 


The Modem Revision ID register is a Dword, read only field. It is composed of the Revision ID 
byte and a 24-bit Class Code register. Its value is loaded from the EEPROM. The Class Code 
identifies the function as a modem. The Class Code and Revision ID are listed in the table below. 


Modem Revision Register 














Bits Default Read/Write Description 
31:24 | 07H Read Only Base Class. This indicates that the 82559 is a communication device. 
23:16 | OOH Read Only Subclass. This indicates the serial controller equals OOH. 
15:8 02H Read Only Program Interface. This indicates that the 82559 is 16550 UART 


compatible and initialized by EEPROM word FEH. 





7:0 XXH Read Only Revision Number. This indicates the revision number and is initialized 
by EEPROM word FEH. 




















Modem Header Type Register 


The Modem Header Type field is a byte wide, read only register. It indicates that this is a 
multifunction card and a value of 80H is hard coded in the silicon. 


Modem I/O Base Address Register 


The Modem I/O BAR is a Dword register that specifies the I/O base address for accessing the 
82559’s modem. The required I/O space is 8 bytes. 


Modem Memory Base Address Register 


The Modem Memory BAR is a Dword register that specifies the memory base address for 
accessing the 82559’s modem port. The required memory space is 512 bytes. The memory space is 
used for both control registers and CIS mapping. 


Modem CardBus CIS Pointer 


The CIS pointer is a Dword, hard coded, read only register. The CIS pointer indicates whether or 
not the CIS structure is located in the memory address space. The physical location of the CIS 
structure is in the serial EEPROM. The EEPROM format is described in Section 4.7, “Serial 
EEPROM Interface” on page 33. 





























Bits R/W Default Description 
31:4 R 0010H Modem CIS Pointer (above the control registers) 
3:0 R 2H CIS in the Memory Base Address Register 





Modem Subsystem Vendor ID Register 


The Modem Subsystem Vendor ID is a 16 bit read only register. Its value is loaded from the 
EEPROM and is a reflection of register 2CH in Function 0, LAN (Ethernet) function. 


Datasheet 


In 


8.2.10 


8.2.11 


8.2.12 


Note: 


8.2.13 


8.2.14 


8.2.15 


Datasheet 


Networking Silicon — 82559 


Modem Subsystem ID Register 


The Modem Subsystem ID is a 16 bit read only register. Its value is loaded from the EEPROM and 
is a reflection of register 2EH in Function 0, LAN (Ethernet) function. 


Modem Capabilities Pointer 


The Modem Capability Pointer is a hard coded, byte register that contains the value DCH. It 
provides an offset within the Configuration Space for the location of the power management 
registers. 


Modem Interrupt Register 


The Modem Interrupt register specifies whether or not the modem requires an interrupt. This 
register is hard coded identically to register 3CH in Function 0, LAN (Ethernet). It indicates that 
the modem requires interrupt support. 


The modem and Ethernet functions share the same INTA# pin. 


Modem Power Management Capabilities Register 


The Modem Power Management Capabilities register is a Dword field that indicates if this function 
has power management capability, as well as identifying which power management capabilities are 
supported. The 82559 reports a value of FE31H if it is connected to an auxiliary power source and 
7E21H otherwise. 


Modem Power Management Control/Status Register 


The Modem Power Management Control/Status Register is a word register. It is used to manage the 
modem’s power management state. It also enables and monitors power management events. The 
Modem Power Management Control/Status Register structure is identical to register EOH in 
Function 0, LAN (Ethernet) function. 


Modem Data Register 
The Modem Data register has similar functionality to register E2H in Function 0, LAN (Ethernet). 


The register at location E2H reports power consumption of the modem function. The value of 
power consumption and power dissipation are loaded from the EEPROM. 


Table 15. Ethernet Data Register 














Data Select | Data Scale Data Reported 
0-3 2 DO to D3 Power Consumption (loaded from 
EEPROM) 
4-7 2 DO to D3 Power Dissipated (loaded from 
EEPROM) 
8-15 0 Reserved (00H) 
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Modem Support in PCI Mode 


The 82559 C-step supports modem interface in PCI mode. The Modem Enable (MDM) bit in the 
EEPROM can be activated in PCI systems without the loss of BootROM support. In addition, 
BootROM support has been simplified. The 82559 C-step supports the co-existence of a BootRom 
Flash device and a modem device (usin CFCS# with external glue logic). This is done by setting 
the MDM bit and clearing the Boot Disable (BD) bit in the EEPROM. With this configuration, both 
the modem function and BootRom BAR are active. The selection between the two functions is 
done through the Boot Enable bit (the least significant bit of BootRom BAR in the LAN PCI 
Configuration space). The 82559 will not support a LAN/modem design if additional companion 
ASICs are operating on the Flash/modem interface. This limitation does not affect companion 
ASICs that reside on the SMB interface of the 82559. 
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Control/Status Registers 





9.1 


LAN (Ethernet) Control/Status Registers 


The 82559’s Control/Status Register (CSR) is illustrated in the figure below. 







































































D31 Upper Word D16 D15 Lower Word DO Offset 
SCB Command Word SCB Status Word 00H 
System Control Block General Pointer 04H 
PORT 08H 
EEPROM Control Register Flash Control Register OCH 
Management Data Interface (MDI) Control Register 10H 
Receive Direct Memory Access Byte Count 14H 
PMDR Flow Control Register Early Receive Int 18H 
Reserved General Status General Control 1CH 
Reserved 20H 
Reserved 24H 
Reserved 28H 
Reserved 2CH 
Function Event Register 30H 
Function Event Mask Register 34H 
Function Present State Register 38H 
Force Event Register 3CH 











Figure 28. 82559 Control/Status Register 
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NOTE: In Figure 28 above, SCB is defined as the System Control Block of the 82559, and PMDR is defined as 
the Power Management Driver Register. 


SCB Status Word: 


SCB Command Word: 


SCB General Pointer: 


PORT Interface: 


Flash Control Register: 


EEPROM Control Register: 


The 82559 places the status of its Command and Receive units and 
interrupt indications in this register for the CPU to read. 


The CPU places commands for the Command and Receive units in 
this register. Interrupts are also acknowledged in this register. 


The SCB General Pointer register points to various data structures 
in main memory depending on the current SCB Command word. 


The PORT interface allows the CPU to reset the 82559, force the 
82559 to dump information to main memory, or perform an internal 
self test. 


The Flash Control register allows the CPU to enable writes to an 
external Flash. 


The EEPROM Control register allows the CPU to read and write to 
an external EEPROM. 
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MDI Control Register: 


Receive DMA Byte Count: 


Flow Control Register: 


PMDR: 


General Control: 


General Status: 


Function Event: 


Function Event Mask: 


Function Present State: 


Force Event: 


72 


intel. 


The MDI Control register allows the CPU to read and write 
information from the PHY unit (or an external PHY component) 
through the Management Data Interface. 


The Receive DMA Byte Count register keeps track of how many 
bytes of receive data have been passed into host memory via DMA. 


This register holds the flow control threshold value and indicates 
the flow control commands to the 82559. 


The Power Management Driver Register provides an indication in 
memory and I/O space that a wake-up interrupt has occurred. The 
PMDR is described in further detail in Section 9.1.11, “Power 
Management Driver Register” on page 75. 


The General Control register allows the 82559 to enter the deep 
power-down state and provides the ability to disable the Clockrun 
functionality. The General Control register is described in further 
detail in Section 9.1.12, “General Control Register” on page 76. 


The General Status register describes the status of the 82559’s 
duplex mode, speed, and link. The General Status register is 
detailed in Section 9.1.13, “General Status Register” on page 76. 


The Function Event Register is used for CardBus power 
management applications and specifies the event that changed the 
status. The Function Event register is further defined in Section 
9.1.14.1, “LAN Function Event Register’ on page 77. 


The Function Event Mask register masks the CSTSCHG signal 
assertion for specified events. The Function Event Mask register is 
further defined in Section 9.1.14.2, “LAN Function Event Mask 
Register” on page 77. 


The Function Present State register reflects the current state of each 
condition that may cause a status change or interrupt. The Function 
Present State register is further defined in Section 9.1.14.3, “LAN 
Function Present State Register” on page 78. 


The Force Event register simulates the status change events for 
troubleshooting purposes. The Force Event register is further 
defined in Section 9.1.14.4, “LAN Force Event Register” on 
page 79. 
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9.1.1 System Control Block Status Word 


The System Control Block (SCB) Status Word contains status information relating to the 82559’s 
Command and Receive units. 





Bits Name Description 





15 Cx Command Unit (CU) Executed. The CX bit indicates that the CU has 
completed executing a command with its interrupt bit set. 





14 ER Frame Received. The FR bit indicates that the Receive Unit (RU) has 
finished receiving a frame. 





CU Not Active. The CNA bit is set when the CU is no longer active and in 
13 CNA , : 
either an idle or suspended state. 





Receive Not Ready. The RNR bit is set when the RU is not in the ready 
12 RNR state. This may be caused by an RU Abort command, a no resources 
situation, or set suspend bit due to a filled Receive Frame Descriptor. 





Management Data Interrupt. The MDI bit is set when a Management Data 
11 MDI Interface read or write cycle has completed. The management data interrupt 
is enabled through the interrupt enable bit (bit 29 in the Management Data 
Interface Control register in the CSR). 
























































10 Swi Software Interrupt. The SWI bit is set when software generates an 
interrupt. 
9 ER Early Receive. The ER bit is used for early receive interrupts. 
FCP Flow Control Pause. The FCP bit is used as the flow control pause bit. 
: Command Unit Status. The CUS field contains the status of the Command 
7:6 CUS Unit 
5:2 RUS Receive Unit Status. The RUS field contains the status of the Receive Unit. 
1:0 Reserved These bits are reserved and should be set to O0b. 
9.1.2 System Control Block Command Word 
Commands for the 82559’s Command and Receive units are placed in this register by the CPU. 
Bits Name Description 
Snacific Specific Interrupt Mask. Setting this bit to 1b causes the 82559 to stop 
31:26 p generating an interrupt (in other words, de-assert the INTA# signal) on the 
Interrupt Mask . 
corresponding event. 
25 SI Software Generated Interrupt. Setting this bit to 1b causes the 82559 to 
generate an interrupt. Writing a Ob to this bit has no effect. 
Interrupt Mask. If the Interrupt Mask bit is set to 1b, the 82559 will not 
24 M assert its INTA# pin. The M bit has higher precedence that the Specific 
Interrupt Mask bits and the SI bit. 
23:20 CUC Command Unit Command. This field contains the CU command. 
19 Reserved This bit is reserved and should be set to Ob. 
18:16 RUC Receive Unit Command. This field contains the RU command. 
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System Control Block General Pointer 


The System Control Block (SCB) General Pointer is a 32-bit field that points to various data 
structures depending on the command in the CU Command or RU Command field. 


PORT 


The PORT interface allows software to perform certain control functions on the 82559. This field is 
32 bits wide: 


¢ Address and Data (bits 32:4) 


¢ PORT Function Selection (bits 3:0) 


The 82559 supports four PORT commands: Software Reset, Self-test, Selective Reset, and 
Dump. 


Flash Control Register 


The Flash Control Register is a 32-bit field that allows access to an external Flash device. 


EEPROM Control Register 


The EEPROM Control Register is a 32-bit field that enables a read from and a write to the external 
EEPROM. 


Management Data Interface Control Register 


The Management Data Interface (MDI) Control register is a 32-bit field and is used to read and 
write bits from the MDI. 











Bits Description 
31:30 These bits are reserved and should be set to O0b. 
29 Interrupt Enable. When this bit is set to 1b by software, the 82559 asserts an interrupt to 


indicate the end of an MDI cycle. 





Ready. This bit is set to 1b by the 82559 at the end of an MDI transaction. It should be reset to 











a Ob by software at the same time the command is written. 
: Opcode. These bits define the opcode: 01 for MDI write and 10 for MDI read. All other values 
27:26 
(00 and 11) are reserved. 
25:21 PHY Address. This field of bits contains the PHY address. 
20:16 PHY Register Address. This field of bits contains the PHY Register Address. 





Data. In a write command, software places the data bits in this field, and the 82559 transfers 
15:0 the data to the PHY unit. During a read command, the 82559 reads these bits serially from the 
PHY unit, and software reads the data from this location. 














Receive Direct Memory Access Byte Count 


The Receive DMA Byte Count register keeps track of how many bytes of receive data have been 
passed into host memory via DMA. 
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Early Receive Interrupt 


The Early Receive Interrupt register allows the 82559 to generate an early interrupt depending on 
the length of the frame. An early interrupt is indicated by the ER bit in the SCB Status Word and 
the assertion of the INTA# signal. 


Flow Control Register 


The Flow Control Register contains the following fields: 


¢ Flow Control Command 


The Flow Control Command field describes the action of the flow control process (for 
example, pause, on, or off). 


¢ Flow Control Threshold 
The Flow Control Threshold field contains the threshold value (in other words, the number of 


free bytes in the Receive FIFO). 


Power Management Driver Register 


The 82559 provides an indication in memory and I/O space that a wake-up event has occurred. It is 
located in the Power Management Driver (PMDR). The PMDR is used for CardBus mode only. 


Power Management Driver Register 





Bits Default Read/Write Description 





31 Ob Read/Clear | Link Status Change Indication. The link status change bit is set 
following a change in link status and is cleared by writing a 1b to it. 





30 Ob Read/Clear | Magic Packet. This bit is set when a Magic Packet is received 
regardless of the Magic Packet wake-up disable bit in the configuration 
command and the PME Enable bit in the Power Management Control/ 
Status Register. This bit is cleared by writing 1b to it. 





29 0b Read/Clear | Interesting Packet. This bit is set when an “interesting” packet is 
received. Interesting packets are defined by the 82559 packet filters. 
This bit is cleared by writing 1b to it. 











28:26 | 000b Read Only Reserved. These bits are reserved and should be set to 000b. 

25 Ob Read/Clear | TCO Request. This bit is set to 1b when the 82559 is busy with TCO 
activity. 

24 Ob Read/Clear | PME Status. This bit is a reflection of the PME Status bit in the Power 


Management Control/Status Register (PMCSR). It is set upon a wake- 
up event and is independent of the PME Enable bit. 


This bit is cleared by writing 1b to it. This also clears the PME Status 
bit in the PMCSR and de-asserts the PME signal. In a CardBus 
system, if 1b is written to this field, the General Wake-up (GWAKE) bit 
in the Function Event register is cleared. 




















The PMDR is initialized at ALTRST# reset only. 
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9.1.12 General Control Register 


The General Control register is a byte register and is described below. The General Control register 
is used in CardBus mode only. 


Table 17. General Control Register 





Bits Default Read/Write Description 





7:2 000000b | Read Only Reserved. These bits are reserved and should be set to 000000b. 





1 Ob Read/Write | Deep Power-Down on Link Down Enable. If a 1b is written to this 
field, the 82559 may enter a deep power-down state (sub-3 mA) in the 
D2 and D3 power states while the link is down. 


In this state, the 82559 does not keep link integrity. This state is not 
supported for point-to-point connection of two end stations. 





0 Ob Read/Write | Clockrun Signal Disable. If this bit is set to 1b, then the 82559 will 
always request the PCI clock signal. This mode can be used to 
overcome potential receive overruns caused by Clockrun signal 
latencies over 5 us. 




















9.1.13 General Status Register 


The General Status register is used in CardBus mode only and is a byte register which indicates the 
link status of the 82559. 


Table 18. General Status Register 

















Bits Default Read/Write Description 

7:3 00000b Read Only Reserved. These bits are reserved and should be set to 00000b. 

2 -- Read Only Duplex Mode. This bit indicates the wire duplex mode: full duplex (1b) 
or half duplex (0b). 

1 -- Read Only Speed. This bit indicates the wire speed: 100 Mbps (1b) or 10 Mbps 
(Ob). 

0 Ob Read Only Link Status Indication. This bit indicates the status of the link: valid 
(1b) or invalid (Ob). 




















9.1.14 Ethernet Card Status Change Registers 


The PME signal used in PCI systems is replaced by the Card Status Change (CSTSCHG) signal in 
CardBus systems. The CardBus specification requires the use of control/status registers related to 
CSTSCHG. There are four event related registers. 


¢ Function Event Register: Specifies the event that changed status 
¢ Function Event Mask Register: Masks CSTSCHG signal assertion for specified events 


¢ Function Present State Register: Reflects the current state of each condition that may cause a 
status change or interrupt 


¢ Force Event Register: Simulates status change events for troubleshooting purposes 


These CardBus registers are used by software to determine which event has occurred, manage the 
event, and control the CSTSCHG signal. 
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registers. These registers compliment the PCI Power Management registers in a non-ACPI 
compliant OS. They are initialized by a power-up reset on the ALTRST# pin. 


The location of these registers should be specified within the configuration space pointing to offset 
address 30H of the CSR. 


Note: Access to the CSTSCHG registers in PCI mode is forbidden. 


9.1.14.1 LAN Function Event Register 


The Function Event register specified the event that changed the status. 


Table 19. LAN Function Event Register 









































Bits Function Default Description 

31:16 Reserved | 0 Bits [31:16] are reserved in the CardBus Specification. 
This bit is used for as the interrupt bit. It is set when the Ethernet 

15 INTR 0b interrupt source is set, regardless of the mask value. It is cleared when 
the OS writes 1b to this field and the interrupt source has been 
serviced. Writing 0b to this field has no effect. 

14:5 Reserved | 0 Bits [14:5] are reserved in the CardBus Specification. 
This bit is used for general wake-up. It is set when the Ethernet wake- 
up source is set, regardless of the mask value. Writing 1b to this field 

4 GWAKE Ob clears this bit and the PME Status bit in the PMCSR. Writing Ob to this 
field has no effect. Note that writing 1b to the PME Status bit in the 
PMCSR has the same effect. 

3 Reserved | Ob Bit 3 is reserved in the CardBus Specification. 

2 BVD RDY | 0b Bit 2 is used as the Battery Voltage Detect Ready (BVD RDY) bit. 

1 BVD WP_ | 0b Bit 1 is used as the BVD Write Protect (WP) bit. 

0 Reserved | 0b Bit 0 is reserved in the CardBus Specification. 








9.1.14.2 LAN Function Event Mask Register 


The Function Event Mask register masks CSTSCHG and INTA# assertion. 


Table 20. LAN Function Event Mask Register 
































Bits Function Default Description 
31:16 | Reserved | 0 Bits [31:16] are reserved in the CardBus Specification. 
This bit is the interrupt mask. When this bit equals Ob, it masks the 
Ethernet function INTA# line but has no effect on the LAN Function 
15 INTR 0b Event register. The Ethernet function can assert the INTA# signal only 
when both fields are enabled: the interrupt bit and the “M” bit in the 
System Control Block (SCB) register within the CSR space. The 
interrupt mask bit affects the INTA# masking. 
This bit is the wake-up mask. When this bit equals Ob, it masks the 
14 WKUP Ob Ethernet function CSTSCHG signal but has no effect on the LAN 
Function Event register. This bit is dependent on bit 4 of this register. 
13:7 Reserved | 0 Bits [13:7] are reserved in the CardBus Specification. 
6:5 PWM 0 These bits are used for Pulse Width Modulation Binary Audio Enable 
. BAM (PWM BAM). 
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Table 20. LAN Function Event Mask Register 























Bits Function Default Description 

This bit is the general wake-up mask. When this bit equals Ob, it masks 
the Ethernet function wake-up events towards the CSTSCHG signal. It 

4 GWAKE Ob has no effect on the LAN Function Event register. The 82559 can 
assert the CSTSCHG signal in the following configuration of masked 
bits: wake-up bit AND general wake-up bit, or PME Enable bit in the 
PMCSR register only. 

3 Reserved | 0b Bit 3 is reserved in the CardBus Specification. 

2 BVD RDY | 0b Bit 2 is used as the Battery Voltage Detect Ready (BVD RDY) bit. 

1 BVD WP_ | 0b Bit 1 is used as the BVD Write Protect (WP) bit. 

0 Reserved | 0b Bit 0 is reserved in the CardBus Specification. 

















9.1.14.3 LAN Function Present State Register 


The Function Present State register reflects the current state of the LAN function that may cause a 
status change or interrupt. 


Table 21. LAN Function Present State Register 





Bits Function Default Description 





31:16 Reserved | 0 Bits [31:16] are reserved in the CardBus Specification. 





This bit is used for interrupts. It reflects the current state of the 
Ethernet source of the interrupt regardless of the mask value. It is set 
15 INTR 0 when the Ethernet function has a pending interrupt and cleared when 
the software driver acknowledges all active interrupts through the SCB 
Command Word. 





14:5 Reserved | 0 Bits [14:5] are reserved in the CardBus Specification. 





This bit is used for general wake-up. It reflects the current state of the 
Ethernet source of CSTSCHG. It is a logical OR result of the gated 
three most significant bits in the PMDR: Link Status Change, Magic 

4 GWAKE 0 Packet, and Interesting Packet. The Link Status change bit is gated by 

the Link Status Change Wake Enable bit in the Configuration 

command. The Magic Packet bit is gated by the Magic Packet Wake-up 
disable bit in the Configuration command. The Interesting Packet bit is 
gated by the programmable filter command. 














3 Reserved | 0b Bit 3 is reserved in the CardBus Specification. 

2 BVD RDY | 0b Bit 2 is used as the Battery Voltage Detect Ready (BVD RDY) bit. 
1 BVD WP_ | 0b Bit 1 is used as the BVD Write Protect (WP) bit. 

0 Reserved | Ob Bit 0 is reserved in the CardBus Specification. 
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9.1.14.4 LAN Force Event Register 


The Force Event register simulates status change events for troubleshooting purposes. This register 
provides the ability to simulate events by forcing values into the Function Event register. 


Table 22. LAN Force Event Register 





Bits Function Default Description 





31:16 Reserved | 0 Bits [31:16] are reserved in the CardBus Specification. 





This bit is used for interrupts. Writing 1b in this field will set the interrupt 
15 INTR 0 bit in the LAN Function Event register. If the INTA# pin is not masked, 
then it will also be activated. Writing Ob has no effect. 





14:5 Reserved | 0 Bits [14:5] are reserved in the CardBus Specification. 





This bit is used for general wake-up. Writing 1b in this field will set the 
4 GWAKE 0 CSTSCHG bit in the LAN Function Event register. If the CSTSCHG pin 
is not masked, then it will also be activated. Writing Ob has no effect. 




















3:0 Reserved | 0 Bits [3:0] are reserved in the CardBus Specification. 





9.2 Statistical Counters 


The 82559 provides information for network management statistics by providing on-chip statistical 
counters that count a variety of events associated with both transmit and receive. The counters are 
updated by the 82559 when it completes the processing of a frame (that is, when it has completed 
transmitting a frame on the link or when it has completed receiving a frame). The Statistical 
Counters are reported to the software on demand by issuing the Dump Statistical Counters 
command or Dump and Reset Statistical Counters command in the SCB Command Unit Command 
(CUC) field. 


Table 23. 82558 Statistical Counters 





ID Counter Description 





0 | Transmit Good Frames This counter contains the number of frames that were 
transmitted properly on the link. It is updated only after the 
actual transmission on the link is completed, not when the 
frame was read from memory as is done for the Transmit 
Command Block status. 





4 | Transmit Maximum Collisions This counter contains the number of frames that were not 
(MAXCOL) Errors transmitted because they encountered the configured 
maximum number of collisions. 





8 | Transmit Late Collisions (LATECOL) | This counter contains the number of frames that were not 
Errors transmitted since they encountered a collision later than the 
configured slot time. 





12 | Transmit Underrun Errors A transmit underrun occurs because the system bus cannot 
keep up with the transmission. This counter contains the 
number of frames that were either not transmitted or 
retransmitted due to a transmit DMA underrun. If the 82559 is 
configured to retransmit on underrun, this counter may be 
updated multiple times for a single frame. 





16 | Transmit Lost Carrier Sense (CRS) | This counter contains the number of frames that were 
transmitted by the 82559 despite the fact that it detected the 
de-assertion of CRS during the transmission. 





20 | Transmit Deferred This counter contains the number of frames that were deferred 
before transmission due to activity on the link. 
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Table 23. 82558 Statistical Counters 


In 





ID 


Counter 


Description 





24 


Transmit Single Collisions 


This counter contains the number of transmitted frames that 
encountered one collision. 





28 


Transmit Multiple Collisions 


This counter contains the number of transmitted frames that 
encountered more than one collision. 





32 


Transmit Total Collisions 


This counter contains the total number of collisions that were 
encountered while attempting to transmit. This count includes 
late collisions and frames that encountered MAXCOL. 





36 


Receive Good Frames 


This counter contains the number of frames that were 
received properly from the link. It is updated only after the 
actual reception from the link is completed and all the data 
bytes are stored in memory. 





40 


Receive CRC Errors 


This counter contains the number of aligned frames discarded 
because of a CRC error. This counter is updated, if needed, 
regardless of the Receive Unit state. The Receive CRC Errors 
counter is mutually exclusive of the Receive Alignment Errors 
and Receive Short Frame Errors counters. 





44 


Receive Alignment Errors 


This counter contains the number of frames that are both 
misaligned (for example, CRS de-asserts on a non-octal 
boundary) and contain a CRC error. The counter is updated, if 
needed, regardless of the Receive Unit state. The Receive 
Alignment Errors counter is mutually exclusive of the Receive 
CRC Errors and Receive Short Frame Errors counters. 





48 


Receive Resource Errors 


This counter contains the number of good frames discarded 
due to unavailability of resources. Frames intended for a host 
whose Receive Unit is in the No Resources state fall into this 
category. If the 82559 is configured to Save Bad Frames and 
the status of the received frame indicates that it is a bad 
frame, the Receive Resource Errors counter is not updated. 





52 


Receive Overrun Errors 


This counter contains the number of frames known to be lost 
because the local system bus was not available. If the traffic 
problem persists for more than one frame, the frames that 
follow the first are also lost; however, because there is no lost 
frame indicator, they are not counted. 





56 


Receive Collision Detect (CDT) 


This counter contains the number of frames that encountered 
collisions during frame reception. 





60 


Receive Short Frame Errors 


This counter contains the number of received frames that are 
shorter than the minimum frame length. The Receive Short 
Frame Errors counter is mutually exclusive to the Receive 
Alignment Errors and Receive CRC Errors counters. A short 
frame will always increment only the Receive Short Frame 
Errors counter. 





64 


Flow Control Transmit Pause 


This counter contains the number of Flow Control frames 
transmitted by the 82559. This count includes both the Xoff 
frames transmitted and Xon (PAUSE(0)) frames transmitted. 





68 








Flow Control Receive Pause 





This counter contains the number of Flow Control frames 
received by the 82559. This count includes both the Xoff 
frames received and Xon (PAUSE(0)) frames received. 
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Table 23. 82558 Statistical Counters 


9.3 


9.3.1 


Datasheet 





ID Counter Description 





72 | Flow Control Receive Unsupported | This counter contains the number of MAC Control frames 
received by the 82559 that are not Flow Control Pause frames. 
These frames are valid MAC control frames that have the 
predefined MAC control Type value and a valid address but 
has an unsupported opcode. 














76 | Receive TCO Frames This counter contains the number of TCO packets received by 
the 82559. 
78 | Transmit TCO Frames This counter contains the number of TCO packets transmitted. 











The Statistical Counters are initially set to zero by the 82559 after reset. They cannot be preset to 
anything other than zero. The 82559 increments the counters by internally reading them, 
incrementing them and writing them back. This process is invisible to the CPU and PCI bus. In 
addition, the counters adhere to the following rules: 


¢ The counters are wrap-around counters. After reaching FFFFFFFFH the counters wrap around 
to 0. 


¢ The 82559 updates the required counters for each frame. It is possible for more than one 
counter to be updated as multiple errors can occur in a single frame. 


¢ The counters are 32 bits wide and their behavior is fully compatible with the IEEE 802.1 
standard. The 82559 supports all mandatory and recommend statistics functions through the 
status of the receive header and directly through these Statistical Counters. 


The CPU can access the counters by issuing a Dump Statistical Counters SCB command. This 
provides a “snapshot”, in main memory, of the internal 82559 statistical counters. The 82559 
supports 21 counters. The dump could consist of the either 16, 19, or all 21 counters, depending on 
the status of the Extended Statistics Counters and TCO Statistics configuration bits in the 
Configuration command (described in the 82559 Software Developer’s Manual). 


Modem Control/Status Registers 


Access to modem based memory or I/O ports are mapped to a cycle to the modem with the lowest 
16 addresses of the PCI address space mapped to the address bus of the modem, which is connected 
to FLA[3:0]. 


Modem Base Memory Addressing 


The modem base memory addressing is an 8-byte address space. There are three types of address 
spaces: 
¢ Modem chipset address space: 0H to FH 


¢ Modem function address space: 80H to FFH (implemented in 82559) 
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9.3.2 


9.3.3 


9.3.3.1 


82 


* Modem CIS address space: 100H to 1FFH (loaded from EEPROM) 











Byte Offset Register Description 
0H:7H Modem controller mimic port, ISA address space 0:7 
0OH:3FH Modem chipset address space (external modem ports) 





Modem controller Resource Management Port (RMP), ISA 




















onEH address space 8:15 
10H:3FH General purpose address space 
80H:83H Modem Control Register: Reset[0], Central Site Mode[1] 
EOH:E3H Reserved 
FOH:F3H Modem Function Event Register 
F4H:F7H Modem Function Mask Register 





F8H:FBH Modem Function Present Register 





FCH:FFH Modem Force Function Event Register 
100H:1FFH CIS Area (loaded from the EEPROM) 




















Modem Base I/O Addressing 


The modem base I/O addressing is an 8-byte address space. During I/O cycles, accesses to the 
modem port are byte accesses. FLA3 is kept low while FLA[2:0] are mapped according to the PCI 
byte address offset. 





Byte Offset Register Description 





0H:7H Venus MIMIC port, ISA address space 0:7 














Modem CardBus CSTCHG Registers 


The modem CardBus CSTCHG registers are used in CardBus mode only. There are four event 
related registers. The CardBus software uses the registers to determine which event has occurred 
and manage the event and to control the CSTSCHG signal. The 82559 supports only the interrupt 
and general wake-up event bits in the CSTSCHG registers. These registers compliment the PCI 
Power Management registers for the use with non-ACPI compliant OS. It is initialized by power-up 
reset driven on the ALTRST# pin. 


Modem Function Event Register 
The Modem Function Event register specifies the event that changed its status. It is identical to the 


Ethernet Function Event register described in Section 9.1.14.1, “LAN Function Event Register” on 
page 77. 
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9.3.3.2 Modem Function Event Mask Register 


The Modem Function Event Mask register masks CSTSCHG and INTA# assertion as shown in 
Table 24 below. 


Table 24. Modem Function Event Mask Register 





Bits Function Default Description 





31:16 Reserved | 0 Bits [31:16] are reserved in the CardBus Specification. 





This bit is the interrupt mask. When this bit equals Ob, it masks the 
modem function INTA# line but has no effect on the Modem Function 
Event register. The modem function can assert the INTA# signal only 
when both fields are enabled: the interrupt bit and the modem control 
15 INTR Ob bit in the System Control Block (SCB) register within the CSR space. 
The interrupt mask bit affects the INTA# masking only after the OS has 
set this register. Thus, on legacy systems that do not access the status 
change registers, the modem INTA# signal is not masked by the 
interrupt. 





This bit is the wake-up mask. When this bit equals Ob, it masks the 
14 WKUP Ob modem function CSTSCHG signal but has no effect on the Function 
Event register. This bit is dependent on bit 4 of this register. 








13:7 Reserved | 0 Bits [13:7] are reserved in the CardBus Specification. 
6:5 PWM 0 These bits are used for Pulse Width Modulation Binary Audio Enable. 
. BAM (PWM BAM). 





This bit is the general wake-up mask. When this bit equals Ob, it masks 
the modem function wake-up events towards the CSTSCHG signal. It 
has no effect on the Modem Function Event register. The 82559 can 
































: ane os assert the CSTSCHG signal in the following configuration of masked 
bits: wake-up bit AND general wake-up bit, or PME Enable bit in the 
PMCSR register only. 

3 Reserved | 0b Bit 3 is reserved in the CardBus Specification. 

2 BVD RDY | 0b Bit 2 is used as the Battery Voltage Detect Ready (BVD RDY) bit. 

1 BVD WP_ | 0b Bit 1 is used as the BVD Write Protect (WP) bit. 

0 Reserved | 0b Bit 0 is reserved in the CardBus Specification. 

9.3.3.3 Modem Function Present State Register 


The Modem Function Present State register specifies the current state of an event’s sources as 
shown in Table 25 below. 


Table 25. Modem Function Present State Register 

















Bits Function Default Description 
31:16 Reserved | 0 Bits [31:16] are reserved in the CardBus Specification. 
15 INTR 0 This bit is used for interrupts. It reflects the current state of the Modem 
Interrupt (MINT) input pin from the modem. 
14:5 Reserved | 0 Bits [14:5] are reserved in the CardBus Specification. 
4 GWAKE 0 This bit is used for general wake-up. It reflects the current inverse state 


of the Modem Ring (MRING#) input pin from the modem. 




















3 Reserved | 0b Bit 3 is reserved in the CardBus Specification. 
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9.3.3.4 
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Bits Function Default Description 
2 BVD RDY | 0b Bit 2 is used as the Batter Voltage Detect (BVD RDY) bit. 
1 BVD WP_ | 0b Bit 1 is used as the BVD Write Protect (WP) bit. 
0 Reserved | Ob Bit 0 is reserved in the CardBus Specification. 




















Modem Force Event Register 


The Modem Force Event register simulates status change events for troubleshooting purposes. It is 
identical to the Ethernet Force Event register described in Section 9.1.14.4, “LAN Force Event 


Register” on page 79. 
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PHY Unit Registers 





10.1 


10.1.1 


Datasheet 


The 82559 provides status and accepts management information via the Management Data 
Interface (MDI) within the CSR space. 


Acronyms mentioned in the registers are defined as follows: 
SC: Self cleared. 
RO: Read only. 
E: EEPROM setting affects content. 
LL: Latch low. 
LH: Latch high. 


MDI Registers 0 - 7 


Register 0: Control Register Bit Definitions 








Bit(s) Name Description Default | R/W 
15 Reset This bit sets the status and control register of the PHY to 0 RW 
their default states and is self-clearing. The PHY returns SC 


a value of one until the reset process has completed and 
accepts a read or write transaction. 


1 = PHY Reset 





14 Loopback This bit enables loopback of transmit data nibbles from 0 RW 
the TXD[3:0] signals to the receive data path. The PHY 
unit’s receive circuitry is isolated from the network. 


Note that this may cause the descrambler to lose 
synchronization and produce 560 nanoseconds of “dead 
time.” 


Note also that the loopback configuration bit takes priority 
over the Loopback MDI bit. 


1 = Loopback enabled 
0 = Loopback disabled (Normal operation) 








13 Speed Selection This bit controls speed when Auto-Negotiation is disabled 1 RW 
and is valid on read when Auto-Negotiation is disabled. 
1 = 100 Mbps 
0 = 10 Mbps 
12 Auto-Negotiation This bit enables Auto-Negotiation. Bits 13 and 8, Speed 1 RW 
Enable Selection and Duplex Mode, respectively, are ignored 


when Auto-Negotiation is enabled. 
1 = Auto-Negotiation enabled 
0 = Auto-Negotiation disabled 





11 Power-Down This bit sets the PHY unit into a low power mode. In low 0 RW 
power mode, the PHY unit consumes no more than 30 
mA. 


1 = Power-Down enabled 
0 = Power-Down disabled (Normal operation) 





10 Reserved This bit is reserved and should be set to Ob. 0 RW 
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Bit(s) Name Description Default | R/W 
9 Restart Auto- This bit restarts the Auto-Negotiation process and is self- 0 RW 
Negotiation clearing. SC 
1 = Restart Auto-Negotiation process 
8 Duplex Mode This bit controls the duplex mode when Auto-Negotiation 0 RW 
is disabled. If the PHY reports that it is only able to 
operate in one duplex mode, the value of this bit shall 
correspond to the mode which the PHY can operate. 
When the PHY is placed in Loopback mode, the behavior 
of the PHY shall not be affected by the status of this bit, 
bit 8. 
1 = Full Duplex 
0 = Half Duplex 
7 Collision Test This bit will force a collision in response to the assertion 0 RW 
of the transmit enable signal. 
1 = Force COL 
0 = Do not force COL 
6:0 Reserved These bits are reserved and should be set to 0000000b. 0 RW 
Register 1: Status Register Bit Definitions 
Bit(s) Name Description Default R/W 
15 Reserved This bit is reserved and should be set to Ob. 0 RO 
E 
14 100BASE-TX Full | 1 = PHY able to perform full duplex 100BASE-TX 1 RO 
Duplex 
13 100 Mbps Half 1 = PHY able to perform half duplex 100BASE-TX 1 RO 
Duplex 
12 10 Mbps Full 1 = PHY able to operate at 10Mbps in full duplex 1 RO 
Duplex mode 
11 10 Mbps Half 1 = PHY able to operate at 10 Mbps in half duplex 1 RO 
Duplex mode 
10:7 Reserved These bits are reserved and should be set to 0000b. 0 RO 
6 Management 0 = PHY will not accept management frames with 0 RO 
Frames Preamble | preamble suppressed 
Suppression 
5 Auto-Negotiation | 1 = Auto-Negotiation process completed 0 RO 
Complete 0 = Auto-Negotiation process has not completed 
4 Remote Fault 0 = No remote fault condition detected 0 RO 
3 Auto-Negotiation | 1 = PHY is able to perform Auto-Negotiation 1 RO 
Ability 
2 Link Status 1 = Valid link has been established 0 RO 
0 = Invalid link detected LL 
1 Jabber Detect 1 = Jabber condition detected 0 RO 
0 = No jabber condition detected LH 
0 Extended 1 = Extended register capabilities enabled 1 RO 
Capability 
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10.1.3 Register 2: PHY Identifier Register Bit Definitions 





Bit(s) Name Description Default R/W 





15:0 PHY ID (high Value: 02A8H -- RO 
byte) 























10.1.4 Register 3: PHY Identifier Register Bit Definitions 















































Bit(s) Name Description Default R/W 
15:0 PHY ID (low byte) | Value: 0154H -- RO 
10.1.5 Register 4: Auto-Negotiation Advertisement Register Bit Definitions 
Bit(s) Name Description Default R/W 
15 Next Page Constant 0 = Transmitting primary capability data 0 RO 
page 
14 Reserved This bit is reserved and should be set to Ob. 0 RO 
13 Remote Fault 1 = Indicate link partner's remote fault 0 RW 
0 = No remote fault 
12:5 Technology Ability | Technology Ability Field is an 8-bit field containing 00101111 | RW 
Field information indicating supported technologies specific 
to the selector field value. 
4:0 Selector Field The Selector Field is a 5-bit field identifying the type of 00001 RO 
message to be sent via Auto-Negotiation. This field is 
read only in the 82559 and contains a value of 
00001b, IEEE Standard 802.3. 























10.1.6 Register 5: Auto-Negotiation Link Partner Ability Register Bit 




















Definitions 
Bit(s) Name Description Default R/W 

15 Next Page This bit reflects the PHY’s link partner’s Auto- -- RO 
Negotiation ability. 

14 Acknowledge This bit is used to indicate that the 82559’s PHY unit -- RO 
has successfully received its link partner's Auto- 
Negotiation advertising ability. 

13 Remote Fault This bit reflects the PHY’s link partner's Auto- -- RO 
Negotiation ability. 

12:5 Technology Ability | This bit reflects the PHY’s link partner's Auto- - RO 

Field Negotiation ability. 

4:0 Selector Field This bit reflects the PHY’s link partner’s Auto- -- RO 

Negotiation ability. 
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10.1.7 Register 6: Auto-Negotiation Expansion Register Bit Definitions 
Bit(s) Name Description Default R/W 
15:5 Reserved These bits are reserved and should be set to Ob. 0 RO 
4 Parallel Detection | 1 = Fault detected via parallel detection (multiple link 0 RO 
Fault fault occurred) sc 
0 = No fault detected via parallel detection LH 
This bit will self-clear on read 
3 Link Partner Next | 1 = Link Partner is Next Page able 0 RO 
page Able 0 = Link Partner is not Next Page able 
2 Next Page Able 1 = Local drive is Next Page able 0 RO 
0 = Local drive is not Next Page able 
1 Page Received 1 = New Page received 0 RO 
0 = New Page not received Sc 
This bit will self-clear on read. LH 
0 Link Partner Auto- | 1 = Link Partner is Auto-Negotiation able 0 RO 
Negotiation Able | 9 — Link Partner is not Auto-Negotiation able 
10.2 MDI Registers 8 - 15 
Registers eight through fifteen are reserved for IEEE. 
10.3 MDI Register 16 - 31 
10.3.1 Register 16: PHY Unit Status and Control Register Bit Definitions 
Bit(s) Name Description Default R/W 
15:14 Reserved These bits are reserved and should be set to 00b 00 RW 
13 Carrier Sense This bit enables the disconnect function. 0 RW 
Disconnect 1 = Disconnect function enabled 
Control : : . 
0 = Disconnect function disabled 
12 Transmit Flow This bit enables Transmit Flow Control 0 RW 
Control Disable 1 = Transmit Flow Control enabled 
0 = Transmit Flow Control disabled 
11 Receive De- This bit indicates status of the 100BASE-TX Receive -- RO 
Serializer In-Sync | De-Serializer In-Sync. 
Indication 
10 100BASE-TX This bit indicates the power state of 1OOBASE-TX 1 RO 
Power-Down PHY unit. 
1 = Power-Down 
0 = Normal operation 
88 Datasheet 


10.3.2 


Datasheet 


Networking Silicon — 82559 
















































































Bit(s) Name Description Default R/W 
9 10BASE-T This bit indicates the power state of 100BASE-TX 1 RO 
Power-Down PHY unit. 
1 = Power-Down 
0 = Normal operation 
8 Polarity This bit indicates 10BASE-T polarity. - RO 
1 = Reverse polarity 
0 = Normal polarity 
7:2 Reserved These bits are reserved and should be set to OB. 000000 | RO 
1 Speed This bit indicates the Auto-Negotiation result. -- RO 
1 = 100 Mbps 
0 = 10 Mbps 
0 Duplex Mode This bit indicates the Auto-Negotiation result. = RO 
1 = Full Duplex 
0 = Half Duplex 
Register 17: PHY Unit Special Control Bit Definitions 
Bit(s) Name Description Default R/W 
15 Scrambler By- 1 = By-pass Scrambler 0 RW 
pass 0 = Normal operations 
14 By-pass 4B/5B 1 =4 bit to 5 bit by-pass 0 RW 
0 = Normal operation 
13 Force Transmit H- | 1 = Force transmit H-pattern 0 RW 
Pattern 0 = Normal operation 
12 Force 34 Transmit | 1 = Force 34 transmit pattern 0 RW 
Pattern 0 = Normal operation 
11 Good Link 1 = 100BASE-TX link good 0 RW 
0 = Normal operation 
10 Reserved This bit is reserved and should be set to Ob. 0 RW 
9 Transmit Carrier 1 = Transmit Carrier Sense disabled 0 RW 
Sense Disable 0 = Transmit Carrier Sense enabled 
8 Disable Dynamic | 1 = Dynamic Power-Down disabled 0 RW 
Power-Down 0 = Dynamic Power-Down enabled (normal) 
7 Auto-Negotiation | 1 = Auto-Negotiation loopback 0 RW 
Loopback 0 = Auto-Negotiation normal mode 
6 MDI Tri-State 1 = MDI Tri-state (transmit driver tri-states) 0 RW 
0 = Normal operation 
5 Filter By-pass 1 = By-pass filter 0 RW 
0 = Normal filter operation 
4 Auto Polarity 1 = Auto Polarity disabled 0 RW 
Disable 0 = Normal polarity operation 
3 Squelch Disable 1 = 10BASE-T squelch test disable 0 RW 











0 = Normal squelch operation 
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Bit(s) Name Description Default R/W 
2 Extended 1 = 10BASE-T Extended Squelch control enabled 0 RW 
Squelch 0 = 10BASE-T Extended Squelch control disabled 

1 Link Integrity 1 = Link disabled 0 RW 
Disable 0 = Normal Link Integrity operation 

0 Jabber Function 1 = Jabber disabled 0 RW 
Disable 0 = Normal Jabber operation 

Register 18: PHY Address Register 
Bit(s) Name Description Default R/W 
15:5 Reserved These bits are reserved and should be set toa 0 RO 
constant ‘0’ 

4:0 PHY Address These bits are set to the PHY’s address, 00001b. 1 RO 
Register 19: 100BASE-TX Receive False Carrier Counter Bit 
Definitions 

Bit(s) Name Description Default R/W 

15:0 Receive False These bits are used for the false carrier counter. -- RO 

Carrier sc 























Register 20: 1OOBASE-TX Receive Disconnect Counter Bit Definitions 
























































Bit(s) Name Description Default R/W 
15:0 Disconnect Event | This field contains a 16-bit counter that increments for -- RO 
each disconnect event. The counter freezes when full sc 
and self-clears on read 
Register 21: 100BASE-TX Receive Error Frame Counter Bit 
Definitions 
Bit(s) Name Description Default R/W 
15:0 Receive Error This field contains a 16-bit counter that increments -- RO 
Frame once per frame for any receive error condition (such sc 
as a symbol error or premature end of frame) in that 
frame. The counter freezes when full and self-clears 
on read. 
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Register 22: Receive Symbol Error Counter Bit Definitions 








Bit(s) Name Description Default R/W 
15:0 Symbol Error This field contains a 16-bit counter that increments for RO 
Counter each symbol error. The counter freezes when full and SC 











self-clears on read. 


In a frame with a bad symbol, each sequential six bad 
symbols count as one. 











Register 23: 100BASE-TX Receive Premature End of Frame Error 
Counter Bit Definitions 



















































































Bit(s) Name Description Default R/W 
15:0 Premature End of | This field contains a 16-bit counter that increments for RO 
Frame each premature end of frame event. The counter sc 
freezes when full and self-clears on read. 
Register 24: 10BASE-T Receive End of Frame Error Counter Bit 
Definitions 
Bit(s) Name Description Default R/W 
15:0 End of Frame This is a 16-bit counter that increments for each end RO 
Counter of frame error event. The counter freezes when full sc 
and self-clears on read. 
Register 25: 10BASE-T Transmit Jabber Detect Counter Bit 
Definitions 
Bit(s) Name Description Default R/W 
15:0 Jabber Detect This is a 16-bit counter that increments for each RO 
Counter jabber detection event. The counter freezes when full SC 
and self-clears on read. 
Register 26: Equalizer Control and Status Bit Definitions 
Bit(s) Name Description Default R/W 
15:0 RFU Reserved for Future Use RW 
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Bit(s) Name Description Default R/W 
15:3 Reserved These bits are reserved and should be set to Ob. 0 RW 
2:0 LED Switch Value ACTLED _LILED 000 RW 

Control 000 Activity Link 
001 Speed Collision 
010 Speed Link 
011 Activity Collision 
100 Off Off 
101 Off On 
110 On Off 
111 On On 
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Introduction 


The 82559’s NAND Tree Test Access Port (TAP) is the access point for test data to and from the 
device. The port provides the ability to perform basic production level testing. The port provides 
two functions: 


¢ The synchronous IC validation mode is used in the production of the device. This mode gives 
the signals their names (for example, Testability Port Clock [TCK]). 


¢ The 82559 also supports asynchronous testing modes. These test modes support the validation 
of connections at the board level. 


Asynchronous Test Mode 


Four asynchronous test modes are supported for system level design use. The modes are selected 
through the use of the test port input pin in static combinations. The test port pins are Test Port 
(TEST), Test Port Data Input (TI), Test Port Execute Enable (TEXEC) and Test Port Clock (TCK). 
During normal operation the TEST pin must be pulled down through a resistor (pulling TEST high 
enables the test mode). All other port inputs may have a pull-down at the designers discretion. 


Test Function Description 


The 82559 TAP mode supports several tests that can be used in board level design. These tests help 
verify basic functionality as well as test the integrity of solder connection on the board. The tests 
are described in the following subsections. 


Tristate 


The tristate command sets all 82559 input and output pins into a tristate (high-Z) mode (all internal 
pull-ups and pull-downs are disabled). This mode is entered by setting the following test pin 
combination and resetting the device: 


TEST =1 TEXEC =0 
TCK =0 Tl=1 
NAND Tree 


The NAND Tree test mode is the most useful of the asynchronous test modes. It enables the 
placement of the 82559 to be validated at board test. The NAND Tree was chosen for its speed 
advantages. Modern automated test equipment can perform a complete peripheral scan without 
support at the board level. This command connects all outputs of the input buffers in the device 
periphery into a NAND Tree scheme. All the output drivers of the output buffers, except the Test 
Port Data Output (TO) pin, are put into high-Z mode. These pins are driven to affect the output of 
the tree. There are two separate chains and associated outputs for speed. Any hard strapped pins 
will prevent the tester from scanning correctly. This mode is entered by placing the test pins in the 
following combination: 


93 


82559 — Networking Silicon 


94 


TEST = 1 TEXEC = 1 
TCK =0 TI=1 


Table 26. NAND Tree Chains 

















































































































Chain Order Chain 1 Chain 2 
(NAND Tree Output) (FLOE#) (FLWE#) 
1 RST# LILED 
2 IDSEL ACTLED# 
3 REQ# SPEEDLED 
4 AD23 SMBALRT# 
5 SERR# SMBCLK 
6 AD22 SMBD 
7 AD21 ISOLATE# 
8 AD20 ALTRST# 
9 AD19 CLKRUN# 
10 AD18 AD31 
11 AD17 AD30 
12 C/BE2# AD29 
13 FRAME# AD28 
14 IRDY# AD27 
15 TRDY# PME# 
16 CLK CSTSCHG 
17 DEVSEL# AD26 
18 INTA# AD25 
19 STOP# C/BE3# 
20 GNT# AD24 
21 PERR# FLDO 
22 PAR FLD1 
23 AD16 FLD2 
24 C/BE1# FLD3 
25 AD15 FLD4 
26 AD14 FLD5 
27 AD13 FLD6 
28 AD12 FLD7 
29 AD11 FLAO 
30 AD10 FLA1 
31 AD9 FLA2 
32 AD8 FLA3 
33 C/BEO# FLA4 








There are two NAND Tree chains with two separate outputs assigned to FLOE# (Chain 1) and 
FLWE# (Chain 2). 
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Chain Order Chain 1 Chain 2 

(NAND Tree Output) (FLOE#) (FLWE#) 
34 AD7 FLA5 
35 AD6 FLA6 
36 AD5 FLA7 
37 AD4 FLA8 
37 AD3 FLA9Q 
39 AD2 FLA10 
40 AD1 FLA11 
41 ADO FLA12 
42 EECS FLA13/EEDI 
43 FLA14/EEDO 
44 FLA15/EESK 
45 FLA16 
46 FLCS# 
47 CFCLK 
48 CFCS# 
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Electrical and Timing Specifications 
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12.2 


Table 27. 


Table 28. 
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Absolute Maximum Ratings 


Maximum ratings are listed below: 


Case Temperature under Bias .... 2.2... ee eee 0Cto 85C 
Storage Temperature ... 5... eee eke ee be eee hence eee ene ete -65 C to 140C 
Outputs and Supply Voltages (except PCI and SMB)..................... -0.5 V to 5.0 V 
PCI and SMB Output Voltages ......... 0.0.0... -0.50 V to 5.25 V 
Transmit Data Output Voltage... 0.2.2... 2. eee ee -0.5 V to 8.0 V 
Input Voltages (except PCI and SMB)........... 0.00.00. eee eee ee -1.0 V to5.0V 
PCI and SMB Input Voltages.... 2.0... 2. . eee -0.5 V 6.0 V 


Stresses above the listed absolute maximum ratings may cause permanent damage to the 82559 
device. This is a stress rating only and functional operations of the device at these or any other 
conditions above those indicated in the operational sections of this specification is not implied. 
Exposure to absolute maximum rating conditions for extended periods may affect device reliability. 


DC Specifications 


General DC Specifications 















































Symbol Parameter Condition Min Typical | Max Units Notes 
Voc Supply Voltage 3.0 3.3 3.5 V 
i Periphery Clamp . 4.75 5.0 5.25 Vv 1 
ardBus 3.0 3.3 3.6 Vv 1 
loc Power Supply 125 195 mA 2 
NOTES: 


1. Vic should be 5 V + 5% in any PCI environment (either 5 V or 3.3 V signaling). In CardBus, Vig must be 
identical to Voc. 

2. Typical current consumption is in nominal operating conditions (Vcc = 3.3 V) and average link activity. 
Maximum current consumption is in maximum Vgc and maximum link activity. 


The 82559 supports both the PCI and CardBus interface standards. In the PCI mode, the 82559 is 
five volts tolerant and supports both 5 V and 3.3 V signaling environments. 


PCl/CardBus Interface DC Specifications 




















Symbol Parameter Condition Min Max Units | Notes 
Vin Input High Voltage 0.475Vc¢c | Vig + 0.5 Vv 
ViLp Input Low Voltage -0.5 0.325Vo¢o Vv 
Vipup Input Pull-up Voltage 0.7Vcc Vv 1 
Vippp Input Pull-down Voltage 0.2Voc Vv 1 
lite Input Leakage Current | 0 < Vin < Voc +10 LA 2 
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Table 28. PCl/CardBus Interface DC Specifications 























lout = -2 mA 2.4 Vv PCI 
VouP Output High Voltage lout = -500 LA 0.9V¢c V 

lout = -150 pA 0.9Vcc V CardBus 

lout = 3 mA, 6 mA 0.55 Vv 3, PCI 
VoLp Output Low Voltage lout = 1500 pA 0.1V¢c Vv 

lout = 700 HA 0.1Voc V CardBus 
Cinp Input Pin Capacitance 10 pF 4 
Ccikp CLK Pin Capacitance 5 12 pF 4 
CipseL IDSEL Pin Capacitance 8 pF 4 
LpiInP Pin Inductance 12 nH 4 


























NOTES: 

1. These values are only applicable in 3.3 V signaling environments (PCI or CardBus). Outside of this limit the 
input buffer must consume its minimum current. 

2. Input leakage currents include high-Z output leakage for all bidirectional buffers with tristate outputs. 

3. Signals without pull-up resistors have 3 mA low output current; and signals requiring pull-up resistors, 6 mA. 
The signals requiring pull-up resistors include: FRAME#, TRDY#, IRDY#, DEVSEL#, STOP#, SERR# and 
PERR#. 

4. This value is characterized but not tested. 


Table 29. SMB Interface DC Specifications 




















Symbol Parameter Condition Min Max Units | Notes 
Vins Input High Voltage 1.4 Vio + 0.5 Vv 
Vics Input Low Voltage -0.5 0.6 Vv 
Input Low Leakage 
lies rae g Vin < Veo +1.0 uA 
VoLs Output Low Voltage IpuLLup = 100 pA 0.4 V 


























NOTE: SMB outputs (SMBALRT#, SMBD, and SMBCLKk) are open drain. 


Table 30. Flash/Modem/EEPROM Interface DC Specifications 


















































Symbol Parameter Condition Min Max Units | Notes 

Vine Input High Voltage 2.0 Voc + 0.5 Vv 

ViLL Input Low Voltage -0.5 0.8 Vv 

Input Low Leakage 

bit, Pan g 0<Vin< Veco +20 uA 

VoHL Output High Voltage lout = -1 mA 2.4 Vv 

VoL Output Low Voltage lout = 2MA 0.4 Vv 

Cine Input Pin Capacitance 10 pF 1 
NOTE: 


1. This value is characterized but not tested. 
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Table 31. LED Voltage/Current Characteristics 






































Symbol Parameter Condition Min Typical | Max Units Notes 
VoHLED Output High Voltage | lou; = -10 mA 2.4 V 
VoLLED Output Low Voltage =| Igy; = 10 MA 0.7 V 





Table 32. 100BASE-TX Voltage/Current Characteristics 





















































Symbol Parameter Condition Min Typical | Max Units Notes 

Rovee _[feutbieenat Tog r Ka 
VipaAtoo Fis tiek Viass +500 0.7 mV 
VipR100 ed Peak Velege +100 mV 
Viewies co Mode Voo/2 V 
Vot00 Se nee 095 | 100 | 1.05 | v 
ne cian RBIAS100 = 619 @ 20 mA 1 
NOTES: 


1. Current is measured on all Vcc pins (Vcc = 3.3 V). 
2. Transmitter peak current is attained by dividing the measured maximum differential output peak voltage by 
the load resistance value. 





Rbias100 
585 Ohm 





619 Ohm 








650 Ohm 








19mA 20 mA 21mA Icct100 











Figure 29. RBIAS100 Resistance Versus Transmitter Current 
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Table 33. 10BASE-T Voltage/Current Characteristics 





















































Symbol Parameter Condition Min Typical | Max Units Notes 

ee cca “ = 

Visio | Abeopt Peak Voltage [SMHz<f<10MHz | #585 | #440 | 23100 | mv 

Vionto | Rbject Poak Voltage [SMHz<f<10MHz | 0 | #440 | +300 | mv 

Wiepae le Mode Voc/2 V 

Vooio | peekVoltlage «| RL= 1000 2.2 2.8 V 

lootio | peso eR SUPPYY | RBIAS10 = 549.0 48 mA 1 
NOTES: 


1. Current is measured on all Voc pins (Vcc = 3.3 V). 
2. Transmitter peak current is attained by dividing the measured maximum differential output peak voltage by 
the load resistance value. 


Figure 30. 


100 





Rbias10 


549 Ohm 


576 Ohm 
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Icct10 








RBIAS10 Resistance Versus Transmitter Current 
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12.3 AC Specifications 


Table 34. AC Specifications for PCI Signaling 




































































Symbol Parameter Condition Min Max Units | Notes 
0< Vie 14 -44 mA 1 
owning 1.4 < Vo, < 0.9V 17.1(Voo - Vow) mA | 1 
lonyac) | Current High ee eee ae 
0.7Vcc < Vout < Voc Eqn A mA 2 
(Test Point) Vout = 0.7Vcc -32Voc mA 2 
Vip =i 95 mA 1 
oun 2.2>Vo4>0.1V Voys/0.023 mA | 4 
lowjac) _ | Current Low qa eee ot 
0.18Vcc > Vout > 0 EqnB | mA 2 
(Test Point) Vout = 0.18Vc¢ 38Vcc mA 2 
Low Clam -25 + (Vin + 1)/ 
Io Current . ovine ane mics 2 
High Clam 25 + (Viq-Vec-1)/ 
laid on camP Vc +4 > Vin2 Veo +1 Om co ma | 3 
slewap cee Rise Joa vto24V 1 4 Vins 
slewep ay Fall lo avtoo.4V 1 4 Vins 
NOTES: 
1. Switching Current High specifications are not relevant to PME#, SERR#, or INTA#, which are open drain 
outputs. 


2. Maximum current requirements will be met as drivers pull beyond the first step voltage (AC drive point). 
Equations defining these maximums (A and B) are provided. To facilitate component testing, a maximum 
current test point is defined for each side of the output driver. 

Equation A. lon = (98/Vec)*(Vout = Voc)«(Vout + 0.4Vcc), for Voc > Vout > 0.7Vcc 
Equation B. Io. = (256/Vec)*(Vout)*(Vec - Vout): for 0 < Vout < 0.18Vec 


3. This parameter is also applicable to CardBus environment. 


Table 35. AC Specifications for CardBus Signaling 











Symbol Parameter Condition Min Max Units | Notes 
tap Para Bs Outbut | o.2Vec to 0.6Vgc 0.25 1.0 | Vins 
tep Cae | O8NeG10.0. Vee 0.25 1.0 | Vins 





























Table 36. AC Specifications for Local Bus Signaling 











Symbol Parameter Condition Min Max Units | Notes 
lou Current Output High 1 mA 
lov Current Output Low 2 mA 
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12.4 Timing Specifications 


12.4.1 Clocks Specifications 


12.4.1.1 PCI/CardBus Clock Specifications 


intel. 


The 82559 uses the PCI Clock signal directly. Figure 31 shows the clock waveform and required 
measurement points for the PCI Clock signal. Table 37 summarizes the PCI Clock specifications. 
























































0.6V 6g 
0.475V og 
0.4V., 0.4V,,, p-to-p 
(minimum) 
0.325V o¢ 
_ Jf 0.2Ve¢ 
T_high T_low 
T_cyc 
Figure 31. PCl/CardBus Clock Waveform 
Table 37. PCI/CardBus Clock Specifications 
Symbol Parameter Min Max Units Notes 
T1 Toye CLK Cycle Time 30 ns 1 
T2 Thigh CLK High Time 11 ns 
T3 | Tiow CLK Low Time 14 ns 
T4 Tslew CLK Slew Rate 1 4 V/ns 2 
NOTES: 


1. The 82559 will work with any PCI clock frequency up to 33 MHz. 
2. Rise and fall times are specified in terms of the edge rate measured in V/ns. This slew rate is met across the 
minimum peak-to-peak portion of the clock waveform as shown in Figure 31. 


12.4.1.2 X1 Specifications 


X1 serves as a signal input from an external crystal or oscillator. Table 38 defines the 82559 
requirements from this signal. 


Table 38. X1 Clock Specifications 









































Symbol Parameter Min Typical Max Units Notes 
T8 Tx1_dce X1 Duty Cycle 40% 60% 
T9 Tx1_pr X1 Period 40 ns +50PPM 
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12.4.2 Timing Parameters 


12.4.2.1 Measurement and Test Conditions 


Figure 32, Figure 33, and Table 39 define the conditions under which timing measurements are 
done. The component test guarantees that all timings are met with minimum clock slew rate 
(slowest edge) and voltage swing. The design must guarantee that minimum timings are also met 
with maximum clock slew rate (fastest edge) and voltage swing. In addition, the design must 
guarantee proper input operation for input voltage swings and slew rates that exceed the specified 
test conditions. 





CLK 


OUTPUT 
DELAY 


Tri-State 
OUTPUT 





> T_on 
ie T_off 

















Figure 32. Output Timing Measurement Conditions 



































V_th 
CLK 
Vit 
V_th * 
inputs 
| . : : : itd vie 
Vth nn re ¥ 
Figure 33. Input Timing Measurement Conditions 
Table 39. Measure and Test Condition Parameters 
Symbol PCI Level CardBus Level | Units Notes 
Vin 0.6Vce¢ 0.6Vcc Vv 
Vi 0.2Voc 0.2Voc¢ Vv 
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Table 39. Measure and Test Condition Parameters 


In 


























Viest 0.4Voc 0.4Vcc Vv 
0.325Vo¢c Vv Min Delay 
Vstep (rising edge) 0.285Voc 
0.475Vocc V__ | Max Delay 
: 0.475Vcc V_ | Min Delay 
Vstep (falling edge) 0.615Voc 
0.325Vc¢c Vv Max Delay 
Vinax 0.4Vcc 0.4Voc V 
Input Signal Edge 
Rate 1 V/ns 




















NOTE: Input test is done with 0.1Vc¢c overdrive. Vmax specifies the maximum peak-to-peak waveform allowed 
for testing input timing. 


12.4.2.2 PCI/CardBus Timings 
Table 40. PCl/CardBus Timing Parameters 




































































Symbol Parameter Min Max | Units Notes 

PCI CLK to Signal Valid Delay 2 11 ns 1,2,4 
14 | teal CardBus CLK to Signal Valid Delay 2 18 | ns 1,3 
TAS | tales Cine, to Signal Valid Delay (point- 2 12 ag 1,2,4 
T16 | ton Float to Active Delay 2 ns 1 
T17 | tot Active to Float Delay 28 ns 1 
T18 | toy Input Setup Time to CLK 7 ns 4,5 
TS | tees ne Setup Time to CLK (point-to- 10 Ag 4,5 
T20 | th Input Hold Time from CLK 0 ns 6 
T21 | test Reset Active Time After Power Stable 1 ms 

penta Active Time After CLK 100 us 6 
122 | Testo CardBus Reset Active Time After CLK 

Stable 100 clocks 6 
T23 | Trst-oft Reset Active to Output Float Delay 40 ns 6,7 
NOTES: 


1. Timing measurement conditions are illustrated in Figure 32. 
2. PCI minimum times are specified with loads as detailed in the PCI Bus Specification, Revision 2.1, Section 

4.2.3.2. 
3. CardBus minimum times are specified with a 0 pF equivalent load. Maximum times are specified with a 30 pF 


equivalent load. Actual test loads may vary but must be correlated to these loads. 


4. na PCl environment, REQ# and GNT# are point-to-point signals and have different output valid delay times 


and input setup times than bussed signals. All other signals are bussed. 
. Timing measurement conditions are illustrated in Figure 33. 
. RST# is asserted and de-asserted asynchronously with respect to the CLK signal. 
. All PCl and CardBus interface output drivers are floated when RST# is active. 
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Flash/Modem Interface Timings 


The 82559 is designed to support up to 150 nanoseconds of Flash access time. The Vpp signal in 
the Flash implementation should be connected permanently to 12 V. Thus, writing to the Flash is 
controlled only by the FLWE# pin. 


Table 41 provides the timing parameters for the Flash interface signals. The timing parameters are 
illustrated in Figure 34 and Figure 35. 


Modem is supported through the Flash interface when the following conditions apply: 


¢ FLA[6:0], FLD[7:0], FLCS#, FLOE#, and FLWE# have the same functions for Flash and 
modem. 


¢ FLA[8] acts as IOCHRDY asynchronous input in modem mode. 


Flash Timing Parameters 


















































Symbol Parameter Min Max | Units Notes 

T35 | ttre Flash Read/Write Cycle Time 150 ag || ae tavay 
T36 | thace FLA to Read FLD Setup Time 150 fe | 2 Fash tavay 
T37 | thes FLCS# to Read FLD Setup Time 150 ne | Flash teLav 
T38 | thoe FLOE# Active to Read FLD Setup Time} 120 nee. | Ba! ‘Lav 
T39. | tat coded Inactive to FLD Driven Delay 50 he ae die! tuaz 
T40 | thas FLA Setup Time before FLWE# 5 ns | 2 pe avi 
T41 | than FLA Hold Time after FLWE# 200 as | = ae NWLax 
T42 | thes FLCS# Hold Time before FLWE# 30 aa pe fewe 
T43 | tich FLCS# Hold Time after FLWE# 30 ns | ae Weed 
T44 | thas FLD Setup Time 150 ns | 2 ee tvwei 
T45. | than FLD Hold Time 10 ns |> Fast WHDX 
T46 | twp Write Pulse Width 120 ns | 2 Flash twLwe 
T47 | tawph Write Pulse Width High 25 ns |> Flash wHwe 
T48 | tioha ee Time after FLWE# or 95 ~ 

T49- | tussns Oe ae Time after FLWE# or 0 ne 
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NOTES: 
1. These timing specifications apply to Flash read cycles. The Flash timings referenced are 28F020-150 
timings. 
2. These timing specifications apply to Flash write cycles. The Flash timings referenced are 28F020-150 
timings. 
FLADDR ZY Address Stable ML: 
T35 
i >| 
FLCS# 
T37 
FLOE# 
FLDATA-R Data In 
T49 T48 
|OCHRDY LLL ZZ 











Figure 34. Flash/Modem Timings for a Read Cycle 

















FLADDR 
FLOS# 
FLWE# 
FLDATA-W 
T49 
IOCHRDY LIE 

















Figure 35. Flash/Modem Timings for a Write Cycle 
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12.4.2.4 EEPROM Interface Timings 


The 82559 is designed to support a standard 64x16 or 256x16 serial EEPROM. Table 42 provides 
the timing parameters for the EEPROM interface signals. The timing parameters are illustrated in 























Figure 36. 
Table 42. EEPROM Timing Parameters 
Symbol Parameter Min Max | Units Notes 

T50 | tersx Serial Clock Frequency 1 Mhz a 7 
T51 |tecgg __| Delay from EECS High to EESK High | 300 ns oo 
T52 |tecsy __| Delay from EESK Low to EECS Low 30 ns ae rs 
T53 | tepis Setup Time of EEDI to EESK 300 ns eee 
T54 | tepiy Hold Time of EEDI after EESK 300 ns eae a 
T55 |tecs EECS Low Time 750 ns aa ies = 
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Figure 36. EEPROM Timings 
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12.4.2.5 PHY Timings 
Table 43. 10BASE-T NLP Timing Parameters 
Symbol Parameter Condition Min Typ Max | Units 
T56 | Trip wid NLP Width 10 Mbps 100 ns 
TS?” | Thip-per NLP Period 10 Mbps 8 24 ms 
T57 
' ‘ 
T56 leo) ! 
Normal Link Pulse 
Figure 37. 10BASE-T NLP Timings 
Table 44. Auto-Negotiation FLP Timing Parameters 
Symbol Parameter Min Typ Max | Units 
T58 | Trip wid FLP Width (clock/data) 100 ns 
T59 | Ttp ck clk | Clock Pulse to Clock Pulse Period 111 125 139 us 
T60 | Trp ck dat | Clock Pulse to Data Pulse Period 55.5 | 62.5 | 69.5 us 
T61 | Trip bur_num | Number of Pulses in one burst 17 33 
T62 | Tip bur wid | FLP Burst Width 2 ms 
T63 | Trp bur_per | FLP Burst Period 8 24 ms 
| T59 I 
Ie a) 
| T60 | | 
is , . | 
T58 ley 
Fast Link Pulse 
se i nae Data Pulse, Gisele Pulse 
\, 162, | 
FLP Bursts 


























Figure 38. Auto-Negotiation FLP Timings 
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Table 45. 100Base-TX Transmitter AC Specification 














Symbol Parameter Condition | Min Typ Max | Units 
TDP/TDN Differential 
T64 | Tjit Output Peak Jitter HLS Data 1400 ps 


























12.4.2.6 SMB Interface Timings 


Table 46. Flash Timing Parameters 























Symbol Parameter Min Max | Units Notes 
femb SMB Operating Frequency 1 MHz 
T84 | tans Data Hold Time 300 ns 
T85 | tysus Data Setup Time 250 ns 
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Package and Pinout Information 





13.1 


Package Information 


The 82559 is a 196-pin Ball Grid Array (BGA) package. Package dimensions are shown in Figure 


39. More information on Intel device packaging is available in the Intel Packaging Handbook, 
which is available from the Intel Literature Center or your local Intel sales office. 
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Figure 39. Dimension Diagram for the 82559 196-pin BGA 
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13.2 Pinout Information 


13.2.1 82559 Pin Assignments 


Table 47. 82559 Pin Assignments 











































































































Pin Name Pin Name Pin Name 
Al NC A2 SERR# A3 VCC 
A4 IDSEL A5 AD25 A6 PME# 
A7 vcc A8 AD30 AQ ALTRST# 
A10 SMBCLK Al1 vcc A12 LILED 
A13 TEST A14 NC 

B1 AD22 B2 AD23 B3 VSSPP 
B4 AD24 B5 AD26 B6 AD27 
B7 VSSPP B8 AD31 BO ISOLATE# 
B10 SMBALRT# B11 SPEEDLED B12 TO 
B13 RBIAS100 B14 RBIAS10 

C1 AD21 C2 RST# C3 REQ# 
C4 C/BE3# C5 CSTSCHG C6 AD28 
C7 AD29 C8 CLKRUN# cg SMBD 
C10 VSSPT C11 ACTLED C12 VREF 
C13 TDP C14 TDN 

D1 AD18 D2 AD19 D3 AD20 
D4 VSS D5 VSS D6 VSS 
D7 VSS D8 VSS D9 NC 
D10 NC D11 VSS D12 Tl 
D13 TEXEC D14 TCK 

EW vcc E2 VSSPP E3 AD17 
E4 VSS E5 VSS E6 VSS 
E7 VSS E8 VSS EQ VSS 
E10 VSS E11 VSS E12 vcc 
E13 RDP E14 RDN 

F1 IRDY# F2 FRAME# F3 C/BE2# 
F4 VSS F5 VSS F6 VSS 
F7 VSS F8 VSS FQ VSS 
F10 VSS F14 VSS F12 FLD2 
F13 FLD1 F14 FLDO 

G1 CLK G2 VIO G3 TRDY# 
G4 NC G5 VCC G6 VCC 
G7 VSS G8 VSS G9 VSS 
G10 VSS G11 VSS G12 FLD3 
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Pin Name Pin Name Pin Name 
G13 VCC G14 VSSPL 

H1 STOP# H2 INTA# H3 DEVSEL# 
H4 NC H5 VCC H6 VCC 
H7 VCC H8 VCC H9 VSS 
H10 VSS H11 VSS H12 FLD6 
H13 FLD5 H14 FLD4 

J1 PAR J2 PERR# J3 GNT# 

J4 NC J5 VCC J6 VCC 

J7 VCC J8 VCC J9 VCC 
J10 VCC J11 vcc J12 FLA1 
J13 FLAO J14 FLD7 

K1 AD16 K2 VSSPP K3 VCC 

K4 VCC K5 VCC K6 VCC 

K7 VCC K8 VCC K9 VCC 
K10 VCC K11 vcc K12 VSSPL 
K13 vcc K14 FLA2 

| AD14 L2 AD15 L3 C/BE#1 

L4 VCC L5 VCC L6 VSS 

L7 CFCS# L8 CFCLK L9 VCC 
L10 VCC L11 VSS L12 FLA5 
L13 FLA4 L14 FLA3 

M1 AD11 M2 AD12 M3 AD13 
M4 C/BEO# M5 AD5 M6 VSSPP 
M7 AD1 M8 FLOE# Mg FLWE# 
M10 FLA15/EESK M11 FLA12 M12 FLA11 
M13 FLA7 M14 FLA6 

N1 VSSPP N2 AD10 N3 AD9 
N4 AD7 N5 AD4 N6 VCC 
N7 ADO N8 voc N9Q FLCS# 
N10 FLA14/EEDO N11 x1 N12 VSSPL 
N13 FLA10 N14 FLA8/IOCHRDY 

P41 NC P2 vcc P3 AD8 

P4 AD6 P5 AD3 P6 AD2 

P7 EECS P8 VSSPL PQ FLA16 
P10 FLA13/EEDI P11 X2 P12 VCC 
P13 FLAQ P14 NC 
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13.2.2 82559 Ball Grid Array Diagram 
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Figure 40. 82559 Ball Grid Array Diagram 
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